• 01


    一、运维:

      1. 介绍服务器。
            服务器逻辑:
                服务器选择
                操作系统
                部署逻辑
    
            业务环境部署逻辑
                业务部署图
                软件部署文档
                日常维护文档
    
            测试
                开发上传代码到源码系统
                上线 - 测服务器,内测
                预发布测试,公测
    
            上线
                产品需求确认
                产品研发确认
                产品测试确认
                产品流程文档
                跟踪统计用户反馈情况
    
        2. 架构部署,自测环境,预生产环境,生产环境。

    二、Nginx:

        Apache: 消耗资源
        Nginx介绍:
            轻量级的WEB服务器,和反向代理服务器
            延伸版本tengine(淘宝)、openresrt(章亦春)等
            官网:http://nginx.org
            中文文档:http://www.nginx.cn/doc/index.html
    
            Nginx管理
            Nginx优化
            Nginx负载均衡
            Nginx缓存
    
        环境:
            1. Vmware虚拟机 2核4G
            2. 网卡:桥接
            3. centos7.5
            4. 防火墙:关闭
            5. Selinux:关闭
            6. 网段:192.168.10.0/24
    
            主机名                  IP             角色
            Master.ayiltuan.com  192.168.10.40  主分发器
            Backup.aliltuan.com  192.168.10.41  备分发器
            Web01.ayituan.com    192.168.10.42  数据服务器1
            Web02.ayituan.com    192.168.10.43  数据服务器2
    
        Nginx目录:
            安装
            相关目录介绍
            启动
            验证测试

    三、Nginx的安装:

       http://nginx.org
    
        1、Nginx安装
            1.1)获得软件 wget http://nginx.org/download/nginx-1.15.5.tar.gz -P /usr/src
            1.2)安装前准备 cd /usr/src tar xf nginx-1.15.5.tar.gz
                cd nginx-1.15.5 yum -y install gcc pcre-devel zlib zlib-devel
    
            1.3)配置
                1)检查环境 是否 满足安装条件     依赖解决
                2)指定安装方式    配置文件   命令文件  各种文件放哪里   开启模块功能【内 置模块  三方模块】
                3)指定软件安装在那里
    
            ./configure --prefix=/usr/local/nginx
    
            1.4)编译   使用gcc将源码生成可执行程序
                make -j4
    
            1.5)安装
                make install
    
        2、相关目录
            nginx path prefix: "/usr/local/nginx"
            nginx binary file: "/usr/local/nginx/sbin/nginx"
            nginx modules path: "/usr/local/nginx/modules"
            nginx configuration prefix: "/usr/local/nginx/conf"
            nginx configuration file: "/usr/local/nginx/conf/nginx.conf"
            nginx pid file: "/usr/local/nginx/logs/nginx.pid"
            nginx error log file: "/usr/local/nginx/logs/error.log"
            nginx http access log file: "/usr/local/nginx/logs/access.log"
    
        3、Nginx启动
            /usr/local/nginx/sbin/nginx
    
        4、验证
            netstat –ntpl
            lsof -i :80
            yum -y install lsof
    
        5、浏览器测试
            elinks
            文本界面浏览器
            elinks http://192.168.10.42  --dump
    
        百度:(方法比技能更重要!)

    四、Nginx的配置文件:

    /usr/local/nginx/conf/nginx.conf

        
        #启动子进程程序默认用户
        #user  nobody;
        #一个主进程和多个工作进程。工作进程是单进程的,且不需要特殊授权即可运行;这里定义的是工作进程数量
        worker_processes  1;
    
        #全局错误日志的位置及日志格式
        #error_log  logs/error.log;
        #error_log  logs/error.log  notice;
        #error_log  logs/error.log  info;
    
        #pid        logs/nginx.pid;
    
    
        events {
            #每个工作进程最大的并发数
            worker_connections  1024;
        }
    
    
        #http服务器设置
        http {
            #设定mime类型,类型由mime.type文件定义
            include       mime.types;
            
            #
            default_type  application/octet-stream;
    
            #日志格式
            #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
            #                  '$status $body_bytes_sent "$http_referer" '
            #                  '"$http_user_agent" "$http_x_forwarded_for"';
            #$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
            #$remote_user:用来记录客户端用户名称;
            #$time_local: 用来记录访问时间与时区;
            #$request: 用来记录请求的url与http协议;
            #$status: 用来记录请求状态;成功是200,
            #$body_bytes_sent :记录发送给客户端文件主体内容大小;
            #$http_referer:用来记录从那个页面链接访问过来的;
            #$http_user_agent:记录客户浏览器的相关信息;
    
            #全局访问日志路径 
            #access_log  logs/access.log  main;
            #sendfile指令指定 nginx 是否调用sendfile 函数(zero copy 方式)来输出文件,对于普通应用,必须设为on。如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络IO处理速度,降低系统uptime。
            sendfile        on;
            
            #此选项允许或禁止使用socke的TCP_CORK的选项,此选项仅在使用sendfile的时候使用
            #tcp_nopush     on;
    
            #长连接超时时间
            #keepalive_timeout  0;
            keepalive_timeout  65;
    
            #开启压缩
            #gzip  on;
    
            #配置虚拟主机
            server {
                #虚拟主机使用的端口
                listen       80;
                #虚拟主机域名
                server_name  localhost;
    
                #虚拟主机支持的字符集
                #charset koi8-r;
    
                #虚拟主机的访问日志路径
                #access_log  logs/host.access.log  main;
    
                #定义web根路径
                location / {
                    #根目录路径
                    root   html;
                    #索引页
                    index  index.html index.htm;
                }
    
                #error_page  404              /404.html;
    
                # redirect server error pages to the static page /50x.html
                #
    
                #根据错误码 返回对应的页面
                error_page   500 502 503 504  /50x.html;
    
                #定义页面路径
                location = /50x.html {
                    root   html;
                }
    
                #定义反向代理服务器 数据服务器是lamp模型
                # proxy the PHP scripts to Apache listening on 127.0.0.1:80
                #
                #location ~ .php$ {
                #    proxy_pass   http://127.0.0.1;
                #}
    
    
                #定义PHP为本机服务的模型  
                # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
                #
                #location ~ .php$ {
                #    root           html;
                #    fastcgi_pass   127.0.0.1:9000;
                #    fastcgi_index  index.php;
                #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
                #    include        fastcgi_params;
                #}
    
                # deny access to .htaccess files, if Apache's document root
                # concurs with nginx's one
                #
                #拒绝apache DR目录及子目录下的.htaccess文件访问
                #location ~ /.ht {
                #    deny  all;
                #}
            }
    
    
            # another virtual host using mix of IP-, name-, and port-based configuration
            #
            #server {
            #    listen       8000;
            #    listen       somename:8080;
            #    server_name  somename  alias  another.alias;
    
            #    location / {
            #        root   html;
            #        index  index.html index.htm;
            #    }
            #}
    
    
            #https的配置方案
            # HTTPS server
            #
            #server {
            #    listen       443 ssl;
            #    server_name  localhost;
    
            #    ssl_certificate      cert.pem;
            #    ssl_certificate_key  cert.key;
    
            #    ssl_session_cache    shared:SSL:1m;
            #    ssl_session_timeout  5m;
    
            #    ssl_ciphers  HIGH:!aNULL:!MD5;
            #    ssl_prefer_server_ciphers  on;
    
            #    location / {
            #        root   html;
            #        index  index.html index.htm;
            #    }
            #}
    
        }

    操作验证:


    useradd -s /sbin/nologin -r www   # 创建一个 www用户

    #启动子进程程序默认用户
    #user nobody;   # www

    worker_processes 1; # 有几个核,就写几个 4

    killall nginx
      yum search killall
      yum -y install psmisc

    /usr/local/nginx/sbin/nginx
    lsof -i :80

    实现了负载均衡;每个工作进程下:最多1024个并发数;

    五、Nginx默认网站、访问控制、登录验证、日志管理、防盗链、日志截断

    ../sbin/nginx -g ../conf/nginx.conf
    验证是否 ok 在重启

    关了,在重启:
      killall nginx
      /usr/local/nginx/sbin/nginx

    重启:
      killall -s HUP nginx

        1、默认网站 
            当Nginx配置⽂文件中有且只有只一个Server的时候,该Server就被Nginx认为是默认网站,
            所有发给Nginx服务器80端⼝口的数据都会默认给该Server.
            
            server {
                listen       80;
                server_name  localhost;
                location / {
                    root   html;
                    index  index.html index.htm;
                }
                error_page   500 502 503 504  /50x.html;
                location = /50x.html {
                    root   html;
                }
            }
    
    
        2、访问控制 
            location /a {
                allow 192.168.1.0/24;
                deny all;
                #return 404;
                return http://www.jd.com;
    
            }
                
            
        3、登陆验证 
                auth_basic
    
            语法:     auth_basic string | off;
    
            默认值:   auth_basic off;
                auth_basic_user_file file;
    
            location /b {
    
                auth_basic ”登陆验证";
                auth_basic_user_file /etc/nginx/htpasswd;
    
            }
        
            
        4、日志管理 
            Nginx访问日志主要有两个参数控制 log_format  
            log_format  #用来定义记录日志的格式(可以定义多种日志格式,取不同名字即 可) access_log  
                        #用来指定日至文件的路径及使用的何种日志格式记录日志 
     
            access_log  logs/access.log  main; 
            
            log_format格式变量:     
                $remote_addr  #记录访问网站的客户端地址     
                $remote_user  #远程客户端用户名     
                $time_local  #记录访问时间与时区     
                $request  #用户的http请求起始行信息     
                $status  #http状态码,记录请求返回的状态码,例如:200、301、404等 
                $body_bytes_sent  #服务器发送给客户端的响应body字节数     
                $http_referer  #记录此次请求是从哪个连接访问过来的,可以根据该参数进 行防盗链设置。     
                $http_user_agent  #记录客户端访问信息,例如:浏览器、手机客户端等     
                $http_x_forwarded_for  #当前端有代理服务器时,设置web节点记录客户端 地址的配置,此参数生效的前提是代理服务器也要进行相关的x_forwarded_for设置 
     
            案例 
                自定义一个json格式的访问日志 
                log_format main_json '{"@timestamp":"$time_local",' 
                    '"client_ip": "$remote_addr",' 
                    '"request": "$request",' 
                    '"status": "$status",' 
                    '"bytes": "$body_bytes_sent",' 
                    '"x_forwarded": "$http_x_forwarded_for",' 
                    '"referer": "$http_referer"' '}'; 
     
            access_log logs/access_json.log main_json; 
        
        
        5、防盗链 
            location /images/ { 
                alias /data/images/; 
                valid_referers none blocked *.ayitula.com; 
                if ($invalid_referer) { 
                    rewrite ^/  http://www.ayitula.com/daolian.gif; 
                    #return 403; 
                } 
            } 
     
        
        6、日志截断 
            mv access.log access.log.0  
            killall -USR1 `cat master.nginx.pid`  
            sleep 1  
            gzip access.log.0
                                                    

    六、Nginx虚拟主机

    就是把一台物理服务器划分成多个“虚拟”的服务器,每一个虚拟主机都可以有独立的域名和独立的目录
    同时发布两个网站:
      DocumentRoot /usr/local/nginx/html/web1
      DocumentRoot /usr/local/nginx/html/web2

            
        1基于IP的虚拟主机 
            
            实现条件: 
                1) 两个IP  
                2)DR 存在 
                3)索引页  index.html  
                #每个网站都需要一个IP   
                #缺点  需要多个IP  如果是公网IP  每个IP都需要付费  
            
            
                逻辑网卡,添加子网卡
                ifconfig
                ifconfig ens33:1 192.168.10.52/24 up
            
                mkdir /usr/local/nginx/html/web1
                mkdir /usr/local/nginx/html/web2
                
                echo web1 > mkdir /usr/local/nginx/html/web1/index.html
                
            配置:
                server {    
                    listen       192.168.10.42:80;     
                    location / {         
                        root   html/web1;         
                        index  index.html index.htm index.php;     
                    } } 
    
                server {     
                    listen       192.168.10.52:80; 
                    location / {         
                        root   html/web2;         
                        index  index.html index.htm;     
                    } }
                    
            
            
            运行:
                ../sbin/nginx -g nginx.conf   # 测试一下。才能关掉,在启动。
                killall nginx
            
                ../sbin/nginx  # 启动
                netstat -ntpl  # 查看已经启动得进程
            
            测试:
                elinks http://192.168.10.42 --dump
                elinks http://192.168.10.52 --dump
                ok
        
        2基于端口的虚拟主机 
        
            #只需要一个IP 
            #缺点  端口你是无法告诉公网用户   无法适用于公网客户   适合内部用户 
            
            ifconfig ens33:1 down
            
            配置:
                server {     
                    listen       80;     
                    #server_name  www.abc.com;     
                    location / {         
                        root   html/web1;         
                        index  index.html index.htm index.php;     
                    } }
                    
                server {     
                    listen       8080;     
                    #server_name  www.abc.com;     
                    location / {         
                        root   html/web2;         
                        index  index.html index.htm;     
                    } } 
                
            启动:    
                ../sbin/nginx -g nginx.conf   # 测试一下。才能关掉,在启动。
                killall nginx
                netstat -ntpl
            
            测试:
                elinks http://192.168.10.42 --dump  # 没加端口,默认是80
                elinks http://192.168.10.42:8080 --dump
                
        3基于域名的虚拟主机
            
            一个网站必然有一个域名 
            配置:
                vim /etc/hosts
                    。。。
                    192.168.10.42  www.abc.com 
                    192.168.10.42  www.cbd.com 
                server {     
                    listen       80;     
                    server_name  www.abc.com; 
                    location / {         
                        root   html/web1;         
                        index  index.html index.htm index.php; 
                    } } 
     
                server {     
                    listen       80;     
                    server_name  www.cbd.com; 
                    location / {         
                        root   html/web2;         
                        index  index.html index.htm;     
                    } } 
            
            测试:
                elinks www.abc.com --dump  # 没加端口,默认是80
                elinks www.cbd.com  --dump
                
  • 相关阅读:
    数据结构(四十七)归并排序(O(nlogn))
    数据结构(四十六)插入排序(1.直接插入排序(O(n²)) 2.希尔排序(O(n3/2)))
    数据结构(四十五)选择排序(1.直接选择排序(O(n²))2.堆排序(O(nlogn)))
    数据结构(四十四)交换排序(1.冒泡排序(O(n²))2.快速排序(O(nlogn))))
    数据结构(四十三)排序的基本概念与分类
    策略模式(strategy pattern)
    多线程同步之读者写者问题
    多线程同步之信号量
    多线程同步之条件变量
    多线程同步之互斥量
  • 原文地址:https://www.cnblogs.com/alice-bj/p/10708337.html
Copyright © 2020-2023  润新知