Nginx1.6.2版本安装遇到的坑以及配置反向代理
本文基于https://www.runoob.com/linux/nginx-install-setup.html教程进行安装,安装过程中和使用中方遇到的坑记录下来。
1.安装过程
本次安装于Fedora33上安装,如果对版本没有要求,可以在Terminal输入nginx让系统进行自动安装。
遇到的坑:
1.Make操作时报错
分析:代码编译过程中将警告当成错误处理
解决方案:打开 nginx的安装目录/objs/Makefile,去掉第二行的-Werror,再重新make
2.make操作时出错
src/os/unix/ngx_user.c: In function ‘ngx_libc_crypt’: src/os/unix/ngx_user.c:36:7: error: ‘struct crypt_data’ has no member named ‘current_salt’ cd.current_salt[0] = ~salt[0]; ^ make[1]: *** [objs/Makefile:774: objs/src/os/unix/ngx_user.o] Error 1 make[1]: Leaving directory ‘/root/nginx-1.10.1‘ make: *** [Makefile:8: build] Error 2
分析:这里提示我们struct crypt_data’没有名为‘current_salt’的成员:cd.current_salt[0] = ~salt[0];最好的办法是换一个版本,因为条件限制,我们就进到源码里把这行直接注释掉好了。
解决方法:
vim src/os/unix/ngx_user.c
#打开文件将cd.current_salt[0] = ~salt[0](35行左右)注释掉
3.make操作出错
报错一长段,往上找到了关键词openssl
分析:openssl版本太高,应该采用1.0.1的版本。
命令查看当前系统自带的版本
解决方案:安装低版本的openssl
sudo wget https://www.openssl.org/source/old/1.0.1/openssl-1.0.1k.tar.gz
tar zxvf openssl-1.0.1k.tar.gz
sudo tar zxvf openssl-1.0.1k.tar.gz
sudo ./config
sudo make && sudo make insatll
opennssl version
#此时我们已经将低版本openssl安装完毕
由于依赖发生更改,所以我们需要重新对nginx生成新的编译指令文本Makefile。
cd ..
cd nginx-1.6.2/
sudo ./configure --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.35 --with-openssl=/usr/local/src/openssl-1.0.1k
注意最后一句的末尾加上–with-openssl=/usr/local/src/openssl-1.0.1k
然后得到了新的Makefile文件。所以在make时会重新遇到第一个问题,我们需要再次按照要求删除-Werror
然后按照操作就能启动nginx了。
2.Nginx反向代理
1.代理失败
首先启动tomcat,然后打开8080无误
server {
listen 8081;
server_name localhost;
location / {
proxy_pass http://127.0.0.1:8080;
index index.html index.htm index.jsp;
}
}
在/usr/local/webserver/nginx/conf/nginx.conf按照格式添加代码
此时应该能在8081端口看到8080端口内类似的效果
此时没有出现想要的效果,找了半天,一开始以为是防火墙原因,然后发现又以为是在其他地方nginx有权重高的配置文件导致未生效,最后发现改错了配置文件。我修改的是nginx安装包中的同名文件,而非nginx安装目录的文件。
关于这点,我们需要详细了解linux编译安装中configure、make和make install各自的作用以及安装过程的事情
首先Nginx是开源软件(大多数Linux软件都是),我们下载和Windows不太的区别在于我们下载的都是源码。源码时不能直接运行的,需要编译成二进制文件才能运行
./configure是用来检测你的安装平台的目标特征的。以及参数传递安装所需的依赖,它是个shell脚本。
make是用来编译的,它从生成的Makefile中读取指令,然后编译。
make install是用来安装的,它也从Makefile中读取指令,安装到指定的位置。
1、configure
这一步一般用来生成 Makefile,为下一步的编译做准备,你可以通过在 configure 后加上参数来对安装进行控制,比如代码:./configure --prefix=/usr上面的意思是将该软件安装在 /usr 下面,执行文件就会安装在 /usr/bin.同时一些软件的配置文件你可以通过指定 --sys-config= 参数进行设定。有一些软件还可以加上 --with、–enable、–without、–disable 等等参数对编译加以控制,你可以通过允许 ./configure --help 察看详细的说明帮助。
2、make
这一步就是编译,大多数的源代码包都经过这一步进行编译(当然有些perl或Python编写的软件需要调用perl或python来进行编译)。如果 在 make 过程中出现 error ,你就要记下错误代码(注意不仅仅是最后一行),然后你可以向开发者提交 bugreport(一般在 INSTALL 里有提交地址),或者你的系统少了一些依赖库等,这些需要自己仔细研究错误代码。make 的作用是开始进行源代码编译,以及一些功能的提供,这些功能由他的 Makefile 设置文件提供相关的功能,比如 make install 一般表示进行安装,make uninstall 是卸载,不加参数就是默认的进行源代码编译。
make 是 Linux 开发套件里面自动化编译的一个控制程序,他通过借助 Makefile 里面编写的编译规范进行自动化的调用 gcc 、ld 以及运行某些需要的程序进行编译的程序。一般情况下,他所使用的 Makefile 控制代码,由 configure 这个设置脚本根据给定的参数和系统环境生成。
3、make install
经过前面两部,我们得到了类似于Windows exe程序的安装包,make install我们将这个安装程序运行得到所需的软件。
这条命令来进行安装(当然有些软件需要先运行 make check 或 make test来进行一些测试),这一步一般需要你有 root 权限(因为要向系统写入文件)
所以修改源码的conf文件没用了。
2.css样式消失
在location js/css等地方也加上 proxy_pass http://127.0.0.1:8080
参考:https://www.jianshu.com/p/c70afbbf5172
https://www.ancii.com/asey6ubbm/
https://blog.youkuaiyun.com/daybreak1209/article/details/51549031