• linux下安装Nginx


    linux下安装Nginx

    (nginx关键字:反向代理,负载均衡)

    1、安装gcc

    安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装:

    yum install gcc-c++
    

    2、PCRE pcre-devel 安装

    PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx也需要此库。命令:

    yum install -y pcre pcre-devel
    

    3、zlib 安装

    zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 Centos 上安装 zlib 库。

    yum install -y zlib zlib-devel
    

    4、OpenSSL 安装
    OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。
    nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 Centos 安装 OpenSSL 库。

    yum install -y openssl openssl-devel
    

    5、下载安装包

    手动下载.tar.gz安装包,地址:https://nginx.org/en/download.html

    下载完毕上传到服务器上 /root

    6、解压

    tar -zxvf nginx-1.18.0.tar.gz
    cd nginx-1.18.0
    

    7、配置

    使用默认配置,在nginx根目录下执行

    1、./configure
    2、make
    3、make install
    

    查找安装路径:

    whereis nginx
    

    Nginx常用命令

    cd /usr/local/nginx/sbin/
    ./nginx  启动
    ./nginx -s stop  停止
    ./nginx -s quit  安全退出
    
    ./nginx -s reload  重新加载配置文件
    	如果报:nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory)
    	因为/usr/local/nginx/logs/nginx.pid这个文件不存在
    	解决:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf,使用nginx -c的参数指定nginx.conf文件的位置,然后进入log目录,发现有了nginx.pid文件,再执行./nginx -s reload
    
    ps aux|grep nginx  查看nginx进程
    

    启动成功访问 服务器ip:80

    注意:如何连接不上,检查阿里云安全组是否开放端口,或者服务器防火墙是否开放端口!
    相关命令:

    **开启**
    service firewalld start
    
    **重启**
    service firewalld restart
    
    **关闭**
    service firewalld stop
    
    **查看防火墙规则**
    firewall-cmd --list-all
    
    **查询端口是否开放**
    firewall-cmd --query-port=8080/tcp
    
    **开放80端口**
    firewall-cmd --permanent --add-port=80/tcp
    
    **移除端口**
    firewall-cmd --permanent --remove-port=8080/tcp
    
    **重启防火墙(修改配置后要重启防火墙)**
    firewall-cmd --reload
    
    **参数解释**
    1、firwall-cmd:是Linux提供的操作firewall的一个工具;
    2、--permanent:表示设置为持久;
    3、--add-port:标识添加的端口;
    

    在配置文件conf/nginx.conf里进行测试

    http {
    	upstream tomcats{
            server 10.200.3.12:8081 weight=1;  #加权轮询
            server 10.200.3.12:8080 weight=2;
        }
    
    
        server {
            listen       80; #设置nginx的访问端口
            location / {
               proxy_pass http://tomcats;#对应upstream tomcats 转发地址
            }
    
            location ~ .(gif|jpg|jpegg|png|bmp|swf|json|html|js|css)$ {     # 正则表达式匹配图片
    
                root  html;   #配置静态资源在html目录下面找
    
            }
    }
    
  • 相关阅读:
    PHP ceil() 函数
    PHP Array 函数
    php中的include()的使用技巧
    [观察者模式]在游戏开发中的应用
    [策略模式]在游戏开发中的应用
    使用EA将源码转化为类图
    PAT 1013 数素数 (20)
    PAT 1034 有理数四则运算(20)
    PAT 1033 旧键盘打字(20)
    PAT 1032 挖掘机技术哪家强(20)
  • 原文地址:https://www.cnblogs.com/A-Nan-q/p/15041065.html
Copyright © 2020-2023  润新知