一、基本的编译与安装

1、安装依赖项

  1. sudo apt-get update
  2. sudo apt-get install build-essential zlib1g-dev libpcre3 libpcre3-dev libssl-dev libxslt1-dev libxml2-dev libgd2-xpm-dev libgeoip-dev libgoogle-perftools-dev libperl-dev libtool
  3. sudo apt-get install openssl

2、下载新版本,到官网复制下载链接

  1. wget http://nginx.org/download/nginx-1.13.5.tar.gz

3、解压

  1. tar -zxvf nginx-1.13..tar.gz

4、编译安装

  1. # 进入解压目录:
  2. cd nginx-1.13.
  3. # 配置:这里额外安装几个模块
  4. ./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-stream --with-mail=dynamic
  5.  
  6. # 编辑nginx:
  7. sudo make
  8. # 安装nginx:
  9. sudo make install
  10. # 启动nginx:
  11. sudo /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
  12. #注意:-c 指定配置文件的路径,不加的话,nginx会自动加载默认路径的配置文件,可以通过 -h查看帮助命令。
  13.  
  14. # 查看nginx进程:
  15. ps -ef|grep nginx
  16.  
  17. # 建立软链接(由于/usr/local/bin包含于$PATH当中,这样就不需要额外的设置环境变量了,这意味着可以在其他路径下直接运行nginx命令)
  18. sudo ln -s /usr/local/nginx/sbin/nginx /usr/local/bin #(创建链接)

编译选项说明:

--prefix=path 如果在编译的不指定安装位置,那么默认的位置/usr/local/nginx目录
--sbin-path=path 设置nginx执行脚本的位置,这里如果设置在path变量里面,就可以在bash环境下,任意使用nginx命令,默认位置prefix/sbin/nginx  注意这里的prefix是在配置文件里面配置的路径
--conf-path=path 配置nginx配置文件的路径,如果不指定这个选项,那么配置文件的默认路径就会是 prefix/conf/nginx.conf
--pid-path =path 配置nginx.pid file的路径,一般来说,进程在运行的时候的时候有一个进程id,这个id会保存在pid file里面,默认的pid file的放置位置是prefix/logs/nginx.pid
--error-log-path=path 设置错误日志的存放路径,如果不指定,就默认 prefix/logs/error.log
--http-log-path= path 设置http访问日志的路径,如果不指定,就默认 prefix/logs/access.log
--user=name 设置默认启动进程的用户,如果不指定,就默认 nobody
--group=name 设置这个用户所在的用户组,如果不指定,依然是nobody
--with-http_ssl_module 开启HTTP SSL模块,使NGINX可以支持HTTPS请求。需要安装了OPENSSL  
--with-http_flv_module  
--with-http_stub_status_module 启用 "server status" 页
--without-http_gzip_module 禁用 ngx_http_gzip_module. 如果启用,需要 zlib
--without-http_ssi_module 禁用 ngx_http_ssi_module  
--without-http_referer_module 禁用 ngx_http_referer_module  
--without-http_rewrite_module 禁用 ngx_http_rewrite_module. 如果启用需要 PCRE 。  
--without-http_proxy_module 禁用 ngx_http_proxy_module  
--without-http_fastcgi_module 禁用 ngx_http_fastcgi_module  
--without-http_memcached_module 禁用 ngx_http_memcached_module  
--without-http_browser_module 禁用 ngx_http_browser_module 
--http-proxy-temp-path=PATH 设置路径到the http proxy temporary files  
--http-fastcgi-temp-path=PATH 设置路径到Set path to the http fastcgi temporary files  
--without-http 禁用 HTTP server
--with-mail 启用 IMAP4/POP3/SMTP 代理模块  
--with-mail_ssl_module 启用ngx_mail_ssl_module  
--with-openssl=DIR 设置路径到OpenSSL library sources  
--with-stream 用来实现四层协议的转发、代理或者负载均衡等

二、ssl的相关配置

1、使用自己生成的证书(仅作测试或加密数据用,不被主流浏览器支持)

  1. # 建立服务器私钥(过程需要输入密码,请记住这个密码)生成RSA密钥
  2. sudo openssl genrsa -des3 -out testcert.key
  3. # 生成一个证书请求
  4. # 需要依次输入国家,地区,组织,email。
  5. # 最重要的是有一个common name,可以写你的名字或者域名。如果为了https申请(不使用自己生成的证书,向CA申请),这个必须和域名吻合,否则会引发浏览器警报。生成的csr文件交给CA签名后形成服务端自己的证书
  6. sudo openssl req -new -key testcert.key -out testcert.csr
  7. # 生成不需要密码的key
  8. sudo openssl rsa -in testcert.key -out testcert_nopwd.key
  9. # 生成crt文件
  10. sudo openssl x509 -req -days -in testcert.csr -signkey testcert_nopwd.key -out testcert.crt

之后将testcert_nopwd.key、testcert.csr、testcert.crt文件复制到 /etc/ssl/certs 目录下

然后配置 nginx.conf 文件

由于在编译中设置的路径是/usr/local/nginx,因此该文件位于/usr/local/nginx/conf 目录下。
打开改文件,在http模块作如下设置:
ssl_certificate /etc/ssl/certs/testcert.crt;
ssl_certificate_key /etc/ssl/certs/testcert.key;

具体的代码:

  1. http {
       #proxy.conf文件参见下文
  2. include proxy.conf;
  3. include mime.types;
  4. default_type application/octet-stream;
  5.  
  6. limit_req_zone $binary_remote_addr zone=one:10m rate=5r/s;
  7. server_tokens off;
  8.  
  9. sendfile on;
  10. #tcp_nopush on;
  11.  
  12. keepalive_timeout ;
  13. client_body_timeout ;
  14. client_header_timeout ;
  15. send_timeout ;
  16. #gzip on;
  17.  
  18. # mvctest只是一个名称
  19. upstream mvctest{
  20. server localhost:;
  21. }
  22.  
  23. server {
  24.  
  25. listen ;
  26. add_header Strict-Transport-Security max-age=;
  27. return https://$host$request_uri;
  28. }
  29.  
  30. server {
  31. listen *: ssl;
  32. server_name localhost;
  33. ssl_certificate /etc/ssl/certs/testcert.crt;
  34. ssl_certificate_key /etc/ssl/certs/testcert.key;
  35. ssl_protocols TLSv1. TLSv1.;
  36. ssl_prefer_server_ciphers on;
  37. ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH";
  38. ssl_ecdh_curve secp384r1;
  39. ssl_session_cache shared:SSL:10m;
  40. ssl_session_tickets off;
  41. ssl_stapling on; #ensure your cert is capable
  42. ssl_stapling_verify on; #ensure your cert is capable
  43.  
  44. add_header Strict-Transport-Security "max-age=63072000; includeSubdomains; preload";
  45. add_header X-Frame-Options SAMEORIGIN;
  46. add_header X-Content-Type-Options nosniff;
  47.  
  48. #Redirects all traffic
  49. location / {
  50. proxy_pass http://localhost:5000;
  51. limit_req zone=one burst= nodelay;
  52. limit_req_status ;
  53. }
  54. }
  55.  
  56. }

自定义的proxy.conf文件内容如下:

  1. proxy_redirect off;
  2. proxy_set_header Host $host;
  3. proxy_set_header X-Real-IP $remote_addr;
  4. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  5. proxy_set_header X-Forwarded-Proto $scheme;
  6. client_max_body_size 10m;
  7. client_body_buffer_size 128k;
  8. proxy_connect_timeout ;
  9. proxy_send_timeout ;
  10. proxy_read_timeout ;
  11. proxy_buffers 4k;

上面定义的区域名称为one(zone=one),分配内存大小为10m(如果限制域的存储空间耗尽了,对于后续所有请求,服务器都会返回 503),
同一个ip($binary_remote_addr)平均处理的请求频率不能超过每秒5次(rate=5r/s); 如果超过每秒5次但超过的请求数量小于等于10(burst=10)时,会延迟请求。
如果超过每秒5次的请求数超过10,则立即返回503(limit_req_status 503)给客户端。

2、申请证书

常用免费证书:https://letsencrypt.org/
通常来说,将CSR文件(生成方式同上,或者按照CA的要求)就是你需要提交给 SSL 认证机构的,当你的域名或组织通过验证后,认证机构就会颁发给你两个文件:test_com.crt和test_com.ca-bundle
而test_com.key是需要用在 Nginx 配置里和test_com.crt、test_com.ca-bundle配合使用的,需要好好保管。

  1. #使用cat命令生成
  2. cat test_com.crt test_com.ca-bundle > test_com.pem

最终得到两个文件:test_com.key和test_com.pem,为了统一位置,可以把这二个文件都移动到 /etc/ssl/private 目录或者 /etc/ssl/cert 目录。
然后可以修改nginx.conf文件,如下:

  1. server {
  2. #...
  3. ssl on;
  4. ssl_certificate /etc/ssl/private/test_com.pem;
  5. ssl_certificate_key /etc/ssl/private/test_com.key;
  6. #...
  7.  
  8. }

同使用自生成证书基本一样,只是重新替换为认证机构颁发的证书而已。

3、迪菲-赫尔曼密钥交换
以上这么做并不安全,默认是 SHA-1 形式,而现在主流的方案应该都避免 SHA-1,为了确保更强的安全性,我们可以采取迪菲-赫尔曼密钥交换
首先,进入/etc/ssl/certs目录,执行命令 sudo  openssl dhparam -out dhparam.pem 4096 生成一个dhparam.pem

  1. test@test-VirtualBox:/etc/ssl/certs$ sudo openssl dhparam -out dhparam.pem 4096
  2. [sudo] test 的密码:
  3. Generating DH parameters, bit long safe prime, generator
  4. This is going to take a long time
  5. # ...会等一段时间,与机器性能有关...
  6. #完成后可以查看生成的文件
  7. test@test-VirtualBox:~$ cd /etc/ssl/certs/
  8. test@test-VirtualBox:/etc/ssl/certs$ ll dhparam.pem
  9. -rw-r--r-- root root 9 : dhparam.pem

修改 nginx.conf 文件,添加 ssl_dhparam /etc/ssl/certs/dhparam.pem; 即可

  1. ssl_prefer_server_ciphers on;
  2. ssl_dhparam /etc/ssl/certs/dhparam.pem;
  3. ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH";

三、启动相关

1、常用命令

  1. #启动 Nginx
  2. /usr/local/nginx/sbin/nginx
  3. ./sbin/nginx 
  4. #停止 Nginx
  5. ./sbin/nginx -s stop
  6. ./sbin/nginx -s quit
  7. # -s都是采用向 Nginx 发送信号的方式。
  8. #Nginx重新加载配置
  9. ./sbin/nginx -s reload
  10. #指定配置文件
  11. ./sbin/nginx -c /usr/local/nginx/conf/nginx.conf
  12. #-c表示configuration,指定配置文件
  13. #查看 Nginx 版本
  14. ./sbin/nginx -v
  15. #帮助
  16. ./sbin/nginx -h
  17. ./sbin/nginx -?

2、自动启动
编译安装需要自己进行设置方可自动启动

  1. # 设置nginx自启动,在/lib/systemd/system/ 目录下创建一个服务文件
  2. vim /lib/systemd/system/nginx.service

内容如下:

  1. [Unit]
  2. Description=nginx - high performance web server
  3. After=network.target remote-fs.target nss-lookup.target
  4.  
  5. [Service]
  6. Type=forking
  7. ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
  8. ExecReload=/usr/local/nginx/sbin/nginx -s reload
  9. ExecStop=/usr/local/nginx/sbin/nginx -s stop
  10.  
  11. [Install]
  12. WantedBy=multi-user.target

文件说明
[Unit]部分
Description:描述服务
After:依赖,当依赖的服务启动之后再启动自定义的服务

[Service]部分
Type=forking是后台运行的形式
ExecStart为服务的具体运行命令(需要根据路径适配)
ExecReload为重启命令(需要根据路径适配)
ExecStop为停止命令(需要根据路径适配)
PrivateTmp=True表示给服务分配独立的临时空间
注意:启动、重启、停止命令全部要求使用绝对路径

[Install]部分
服务安装的相关设置,可设置为多用户

  1. # 设置了自启动后,任意目录下执行
  2. systemctl enable nginx.service
  3. # 启动nginx服务
  4. systemctl start nginx.service
  5. # 设置开机自动启动
  6. systemctl enable nginx.service
  7. # 停止开机自动启动
  8. systemctl disable nginx.service
  9. # 查看状态
  10. systemctl status nginx.service
  11. # 重启服务
  12. systemctl restart nginx.service
  13. # 查看所有服务
  14. systemctl list-units --type=service

四、可能遇到的问题
nginx: [emerg] SSL_CTX_use_PrivateKey_file("/etc/ssl/certs/testcert.key") failed (SSL: error:0906406D:PEM routines:....
nginx启动的时候需要输入证书密码,解决办法是可以使用私钥来生成解密后的key来代替,效果是一样的(就跟ssh连接差不多),达到免密码重启的效果:
openssl rsa -in testcert.key -out untestcert.key
接下来你只需要在nginx里面使用新的untestcert.key即可使用https连接了。

nginx: [emerg] zero size shared memory zone "oneip"
出现此错误都是因为在未指定limit_req_zone指定就使用了limit_req指令的原因(或者limit_req中的name值和limit_req_zone中定义的name值不一致)。

ubuntu环境下nginx的编译安装以及相关设置的更多相关文章

  1. ubuntu环境下python虚拟环境的安装

    一. 虚拟环境搭建 在开发中安装模块的方法: pip install 模块名称 之前我们安装模块都是直接在物理环境下安装,这种安装方法,后面一次安装的会覆盖掉前面一次安装的.那如果一台机器上面开发多个 ...

  2. Ubuntu环境下使用Maven编译并打包Java项目

    一.安装Maven 打开终端输入以下指令: $ mvn -v Apache Maven Maven home: /usr/share/maven Java version: 1.8.0_181, ve ...

  3. Ubuntu环境下使用npm编译从git上clone下来的前端(Javascript)项目

    一.更新Ubuntu软件源 打开终端依次输入: $ sudo apt-get update $ sudo apt-get install -y python-software-properties s ...

  4. 【笔记JS/HTML/CSS】ubuntu环境下的sublime text2 安装 zenCoding

    刚接触web编程的时候就被老师安利了sublime text2 这个文本编辑器,后来发现它真的挺好用的,无论是windows还是ubuntu,都可以很简单地下载安装(到官网,免费哦),三分钟内就搞定了 ...

  5. Ubuntu环境下利用ant编译nutch2.2.1 & 配置nutch2.2.1

    /×××××××××××××××××××××××××××××××××××××××××/ Author:xxx0624 HomePage:http://www.cnblogs.com/xxx0624/ ...

  6. windows环境下nginx服务器的安装与配置

    转载至:http://www.cnblogs.com/hxxy2003/archive/2012/09/20/2695254.html nginx服务器是一个高性能的HTTP和反向代理服务器,它以稳定 ...

  7. Ubuntu/CentOS下源码编译安装Php 5.6基本参数

    先确认安装libxml2 apt-get install libxml2 libxml2-dev或者yum install libxml2 libxml2-dev ./configure --pref ...

  8. Nginx 的编译安装和URL地址重写

    本文转自:http://www.178linux.com/14119#rd?sukey=ecafc0a7cc4a741b573a095a3eb78af6b4c9116b74d0bbc9844d8fc5 ...

  9. Go学习笔记(一):Ubuntu 环境下Go的安装

    本文是根据<Go Web 编程>,逐步学习 Ubuntu 环境下go的安装的笔记. <Go Web 编程>的URL地址如下: https://github.com/astaxi ...

随机推荐

  1. Photoshop打开时报错“不能打开暂存盘文件。。。”

    解决方法: 1.找到应用程序(Photoshop.exe文件) 2.右键 -> 属性 -> 兼容性 -> 更改所有用户的设置 -> 勾选上“以管理员身份运行此程序”.

  2. 关于HashSet在 java7 与 java8的不同

    作者:RednaxelaFX链接:https://www.zhihu.com/question/28414001/answer/40733996来源:知乎著作权归作者所有.商业转载请联系作者获得授权, ...

  3. golang函数学习笔记

    golang函数特点: a.不支持重载,一个包不能有两个名字一样的函数 b.函数是一等公民,函数也是一种类型,一个函数可以赋值给变量 c.匿名函数 d.多返回值   例子1 func add(a, b ...

  4. 前端开发 - HTML - 总结

    html head标签 title 显示网站的标题 meta 提供有关页面的原信息 link 链接css资源文件.网站图标 style 定义内部样式表 script 链接脚本js文件 body标签 块 ...

  5. python - 用户交互/数据类型/格式化输出/运算符/流程控制单双多分支

    python:用户交互: 等用户输入,做反应: username=input("username:")password=input("password:")pr ...

  6. 剑指Offer——链表中环的入口结点

    题目描述: 一个链表中包含环,请找出该链表的环的入口结点. 分析: 设置两个指针p1,p2, 两个指针都从链表的头部开始走,不过p1每次走一步,p2每次走两步. 直到相遇的时候,p2走的长度是p1的两 ...

  7. Mysql中字段类型之时间戳大坑2

      本文的内容依旧是讨论mysql字段类型为时间戳timestamp的问题,在遇到了之前的那个问题之后,今天测试人员又给我提了一个bug,是在前端页面提交会议表单的时候,选择了一个会议时间(2059年 ...

  8. SQL Server扩展事件-- 使用system_health默认跟踪会话监控死锁

    SQL Server扩展事件(Extended Events)-- 使用system_health默认跟踪会话监控死锁 转自:http://blog.51cto.com/ultrasql/160037 ...

  9. Android ListView工作原理完全解析(转自 郭霖老师博客)

    原文地址:http://blog.csdn.net/guolin_blog/article/details/44996879 在Android所有常用的原生控件当中,用法最复杂的应该就是ListVie ...

  10. (转)C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区

    程序在内存有五个存在区域: A:动态区域中的栈区  B:动态区域中的栈区 C:静态区域中:全局变量 和静态变量    (这个区域又可以进一步细分为:初始化的全局变量和静态变量    以及    未初始 ...