前言:
本文参考了jackyzm的博客:https://www.cnblogs.com/jackyzm/p/9600738.html,进行了内容的更新,并请注意这里适用的版本是centos7的版本。并且本文的配置方式曾经在版本8上失败过,因此查看本文前最好先确定服务器的版本。
而关于nginx部分问题的处理,则是参考了文章:http://www.mamicode.com/info-detail-3008792.html进行,其中包括的部分错误如下:
1.make[1]: *** [objs/Makefile:473: objs/src/core/ngx_murmurhash.o] Error 1
2.make[1]: *** [objs/Makefile:774: objs/src/os/unix/ngx_user.o] Error 1
3.make[1]: *** [objs/Makefile:769: objs/src/event/ngx_event_openssl.o] Error 1
本文针对这些问题和一些其他问题的解决方案都进行了阐述和流程上的改良
内容流程:
0.前置说明,1.安装gcc环境,2.安装pcre库,3.安装ssl库,4.安装zlib库,5.安装nginx,附:nginx在make过程中可能出现的问题,6.nginx启动与使用,7.nginx启动后无法访问的问题解决
具体内容:
0.前置说明
在centos系统中,yum源不直接提供nginx的安装,因此可以通过切换yum源的方法进行nginx的安装,也可以通过直接下载依赖库和nginx安装包的方法来实现,本文介绍的是后者。
一些必要的库和nginx的关系:nginx 中gzip模块需要 zlib 库,rewrite模块需要 pcre 库,ssl 功能需要openssl库
然后本文将选定/usr/local为安装目录,一些库的具体版本号各位可根据实际改变,但由于互相依赖,所以最新的可能存在一些问题,谨慎选择。
且以下命令均需在root权限下执行
1.安装gcc gcc-c++(如新环境,未安装请先安装)
$ yum install -y gcc gcc-c++
2.安装pcre库
$ cd /usr/local/ $ wget https://sourceforge.net/projects/pcre/files/pcre/8.36/pcre-8.36.tar.gz
(注:pcre版本会实时更新,8.36版本同样是旧版本,如果需要最新版本自行搜索pcre即可,然后选择新版本,不过新版本可能会不太稳定,需要注意。
当前网址获取新版本的方法为访问:https://sourceforge.net/projects/pcre/files/pcre/)
$ tar -zxvf pcre-8.36.tar.gz $ cd pcre-8.36 $ ./configure $ make && make install
如报错:configure: error: You need a C++ compiler for C++ support
解决方案:yum install -y gcc gcc-c++
3.安装ssl库
$ cd /usr/local/ $ wget https://www.openssl.org/source/openssl-1.0.1j.tar.gz
(注:openssl同样有版本更新,这里为2020.04的版本,当前网址获取新版本的方法为访问:https://www.openssl.org/source/
这里没有采用1.1.x等版本是因为在后面安装nginx出现了无法解决的错误,所以选择了这一较久的版本,如果可以解决,可以进行尝试,如果能告知解决方案或者成功案例就更感谢了)
$ tar -zxvf openssl-1.0.1j.tar.gz $ cd openssl-1.0.1j $ ./config $ make && make install
4.安装zlib库
$ cd /usr/local/ $ wget http://zlib.net/zlib-1.2.11.tar.gz
(注:同前,版本更新网址为:http://zlib.net/)
$ tar -zxvf zlib-1.2.11.tar.gz $ cd zlib-1.2.11 $ ./configure $ make && make install
5.安装nginx
$ cd /usr/local/ $ wget http://nginx.org/download/nginx-1.8.0.tar.gz
(注:同前,获取新版本的网址为:http://nginx.org/download/)
$ tar -zxvf nginx-1.8.0.tar.gz $ cd nginx-1.8.0 $ ./configure --user=nobody --group=nobody --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_gzip_static_module --with-http_realip_module --with-http_sub_module --with-http_ssl_module--with-pcre=/usr/local/pcre-8.36 --with-zlib=/usr/local/zlib-1.2.11--with-openssl=/usr/local/openssl-1.0.1j
(注: --with-http_ssl_module:这个不加后面在nginx.conf配置ssl:on后,启动会报nginx: [emerg] unknown directive "ssl" in /opt/nginx/conf/nginx.conf 异常;儿针对pcre、zlib和openssl等等的指定,则是为了保证nginx能够和之前下载的版本匹配一致,注意路径和版本号需要修改为和之前下载对应的样子)
$ make && make install
附:nginx在make过程中可能出现的问题:
报错1:make[1]: *** [objs/Makefile:460: objs/src/core/ngx_murmurhash.o] Error 1
将警告视为报错进行了程序终止
解决方案:进入到nginx安装目录的objs文件夹中,修改Makefile文件:
按下a进入编辑模式,将CFLAGS中的-Werror去除,然后按下esc,输入:wq保存退出
然后再次进行尝试make && make install指令
报错2:make[1]: *** [objs/Makefile:747: objs/src/os/unix/ngx_user.o] Error 1
提示我们struct crypt_data'没有名为‘current_salt'的成员:cd.current_salt[0] = ~salt[0];原文作者说最好的办法是换一个版本,这里开始选择的1.9出现了报错,但是切换成了nginx1.8后还是没有效果,因此便在nginx1.8的基础上使用了替代方案:代码注释
即在nginx安装目录下通过执行vim src/os/unix/ngx_user.c,对ngx_user.c第36行的代码进行注释,前后如下:
然后保存退出,再次尝试make && make install
报错3:make[1]: *** [objs/Makefile:769: objs/src/event/ngx_event_openssl.o] Error 1
说明ssl版本没有告知nginx,应该是前面./configure的时候没有指定ssl版本导致的,需要重新configure,即需要在configure时增加ssl的指定。
--with-openssl=/usr/local/openssl-1.0.1j
报错4:./configure: error: SSL modules require the OpenSSL library.
可以尝试执行指令:
yum -y install openssl openssl-devel
报错5:./configure: error: the HTTP gzip module requires the zlib library
configure时没有制定好另外两个库的路径,在–prefix后面接以下命令(具体使用方式见./configure指令的执行):
--with-pcre=/usr/local/pcre-8.36指的是pcre-8.36的源码路径。--with-zlib=/usr/local/zlib-1.2.11 指的是zlib-1.2.11 的源码路径。
如果以上报错还是无法解决问题,最好查看centos版本是否是7,我就是在更换系统版本后直接成功的。如果遇到其他报错,最好进行检索,无法解决十分抱歉。
6.nginx启动与使用
$ /usr/local/nginx/sbin/nginx
启动成功的标志:打开浏览器访问服务器的ip地址,如果浏览器出现Welcome to nginx! 则表示 nginx 已经安装并运行成功。
其他的一些命令如下:
重启:
$ /usr/local/nginx/sbin/nginx -s reload
停止:
$ /usr/local/nginx/sbin/nginx -s stop
测试配置文件是否正常:
$ /usr/local/nginx/sbin/nginx -t
强制关闭:
$ pkill nginx
注:这里没有设置软链接,因此只能通过这么长的指令进行管理,如有需要可自行检索处理,后面如果我有时间也会更新到本文中。
7.nginx启动后无法访问的问题解决
这里如果还看不到nginx的页面,可能是服务器的安全组没有配置导致的,例如阿里云就需要在这里添加http,端口80的配置,如下:
安全组配置之后只需刷新页面即可看到nginx的成功页面。
最后祝各位配置顺利。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。