1、Nginx的安装nginx
(1)因为nginx的一些模块依赖一些lib库,因此在安装nginx以前,必须先安装这些lib库,这些依赖库主要有g++、gcc、openssl-devel、pcre-devel和zlib-devel 因此执行以下命令安装:c++
$ yum install gcc-c++
$ yum install pcre pcre-devel
$ yum install zlib zlib-devel
$ yum install openssl openssl--devel session
(2)安装以前,最好检查一下是否已经安装有nginxdom
$ find -name nginx ui
若是系统已经安装了nginx,那么就先卸载spa
$ yum remove nginx code
(3)首先进入/usr/local目录server
$ cd /usr/local blog
从官网下载最新版的nginx进程
$ wget http://nginx.org/download/nginx-1.8.1.tar.gz
(4)解压nginx压缩包
$ tar -zxvf nginx-1.8.1.tar.gz
会产生一个nginx-1.8.1 目录,这时进入nginx-1.8.1目录
$ cd nginx-1.8.1
(5)接下来安装,使用--prefix参数指定nginx安装的目录,make、make install安装
$ ./configure $默认安装在/usr/local/nginx
$ make
$ make install
(6)若是没有报错,顺利完成后,最好看一下nginx的安装目录
$ whereis nginx
安装完毕后,进入安装后目录(/usr/local/nginx)即可以启动或中止它了。
2、Nginx的HTTPS配置
1.修改nginx.conf的相关位置
server {
listen 80;
listen 8011;
listen 10443 ssl;
server_name localhost;
#ssl on;
ssl_certificate /root/ssl/server.cer;
ssl_certificate_key /root/ssl/private.key;
ssl_session_timeout 5m;
ssl_protocols SSLv2 SSLv3 TLSv1;
ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
ssl_prefer_server_ciphers on;
# autoindex on;
# autoindex_exact_size_off;
....
2.执行/nginx -t,若是出现“nginx: [emerg] unknown directive "ssl" in ...”错误的处理:
(1)到解压的nginx目录下
$ cd nginx-1.8.1
$ ./configure --with-http_ssl_module
若是出现:./configure: error: SSL modules require the OpenSSL library.
须要安装:
$ yum -y install openssl openssl-devel
再执行:
$ ./configure
从新执行:
$ ./configure --with-http_ssl_module
$ make --注:切记不能make install 会覆盖。
(2)备份原来nginx
$ cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak
$ cp objs/nginx /usr/local/nginx/sbin/nginx
(3) 重启nginx
$ /usr/local/nginx/sbin/nginx -s reload
注:但有时候执行nginx -s reload 不是很管用,须要kill -9 nginx进程,再从新启动。
(记一次在配置nginx SSL时踩过的坑,执行nginx -s reload后,telnet 127.0.0.1 443 发现端口怎 么也不通,就这样折腾了很久,最后把nginx的进程kill了,重启启动,才OK了)
|
2.openssl s_client -tls1_1 -connect you.domain.com
:443 能够查看SSL对TLS版本的支持
若是出现上图,表示支持。
表示不支持。