linux环境下安装nginx(并部署静态文件)

简介: linux环境下安装nginx(并部署静态文件)

linux环境下安装nginx



1.安装nginx所需环境


1.1 安装 gcc

命令:yum install gcc-c++

(弹出选项,输入 y 即可)

1.2 安装 PCRE

命令:yum install -y pcre pcre-devel

1.3 安装 zlib

命令:yum install -y zlib zlib-devel

1.4 安装 openssl

命令: yum install -y openssl openssl-devel


2.编译安装


2.1 上传压缩包到指定目录


2.2 解压nginx压缩包:tar -zxvf nginx-1.8.0.tar.gz


2.3 查询配置参数,各个参数意思,此处不列举:./configure --help


2.4 参数设置(仅供参考,路径配置可不同,均属于加载,安装路径,可直接使用):


./configure

–prefix=/usr/local/nginx

–pid-path=/var/run/nginx/nginx.pid

–lock-path=/var/lock/nginx.lock

–error-log-path=/var/log/nginx/error.log

–http-log-path=/var/log/nginx/access.log

–with-http_gzip_static_module

–http-client-body-temp-path=/var/temp/nginx/client

–http-proxy-temp-path=/var/temp/nginx/proxy

–http-fastcgi-temp-path=/var/temp/nginx/fastcgi

–http-uwsgi-temp-path=/var/temp/nginx/uwsgi

–http-scgi-temp-path=/var/temp/nginx/scgi

注意:此处将临时文件路径设置为:/var/temp/nginx/client,需要手动在var目录下新建temp,在temp下新建nginx目录,以及下面的client。


2.5 编译安装:make install (此处命令,在解压后的nginx-1.8.0目录下直接执行,nginx安装在:/usr/local/nginx)


2.6 查看安装路径

cd /usr/local/nginx

有三个文件夹:conf、sbin、html

conf下面是配置文件,主要是nginx.conf

sbin下面是nginx文件。


2.7 启动nginx:

cd /usr/local/nginx/sbin

./nginx


2.8 查询nginx进场:ps aux|grep nginx

后面跟着./nginx是主进程

另一个则是工作进程


2.8 停止nginx

方式一:./nginx -s stop ()

此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

方式二:./nginx -s quit

此方式停止步骤是待nginx进程处理任务完毕进行停止。


2.9 重启nginx

./nginx -s reload

用于改动了nginx.conf 后重新加载配置文件,使配置文件生效。


2.10 测试是否成功(ip+80默认端口)


2020102520551417.png


3. 开机自启动nginx


3.1 vi /etc/init.d/nginx 输入下面内容

作用:可以直接使用此处脚本对ng进行操作,如

查看状态:/etc/init.d/nginx status

启动:/etc/init.d/nginx start

停止:/etc/init.d/nginx stop

重启:/etc/init.d/nginx restart


#!/bin/bash
# nginx Startup script for the Nginx HTTP Server
# it is v.0.0.2 version.
# chkconfig: - 85 15
# description: Nginx is a high-performance web and proxy server.
#              It has a lot of features, but it's not for everyone.
# processname: nginx
# pidfile: /var/run/nginx.pid
# config: /usr/local/nginx/conf/nginx.conf
nginxd=/usr/local/nginx/sbin/nginx
nginx_config=/usr/local/nginx/conf/nginx.conf
nginx_pid=/var/run/nginx.pid
RETVAL=0
prog="nginx"
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ ${NETWORKING} = "no" ] && exit 0
[ -x $nginxd ] || exit 0
# Start nginx daemons functions.
start() {
if [ -e $nginx_pid ];then
   echo "nginx already running...."
   exit 1
fi
   echo -n $"Starting $prog: "
   daemon $nginxd -c ${nginx_config}
   RETVAL=$?
   echo
   [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx
   return $RETVAL
}
# Stop nginx daemons functions.
stop() {
        echo -n $"Stopping $prog: "
        killproc $nginxd
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid
}
# reload nginx service functions.
reload() {
    echo -n $"Reloading $prog: "
    #kill -HUP `cat ${nginx_pid}`
    killproc $nginxd -HUP
    RETVAL=$?
    echo
}
# See how we were called.
case "$1" in
start)
        start
        ;;
stop)
        stop
        ;;
reload)
        reload
        ;;
restart)
        stop
        start
        ;;
status)
        status $prog
        RETVAL=$?
        ;;
*)
        echo $"Usage: $prog {start|stop|restart|reload|status|help}"
        exit 1
esac
exit $RETVAL


3.2 设置该文件为所有用户可以访问

chown a+x /etc/init.d/nginx

(a 是all的意思,x 是execute的意思)


3.3 配置开机重启

打开rc.local 文件 :vi /etc/rc.local

最下方加入: /etc/init.d/nginx start


4.部署一个静态文件


4.1 打开安装目录下的配置文件(这里是:/usr/loacal/nginx/conf/nginx.conf)

vi nginx.conf


在location中配置路径和页面,如下图:


20201025212218551.png


此外,最好在server中将默认的80端口更改掉,80容易端口冲突,这里改成8081了,如图


20201025212431263.png


4.2 ifconfig查看端口,ip+port访问测试,出来也页面就成功了。


20201025212703716.png


如有不对之处,请指证。


记录下阿里云服务器部署nginx静态页面问题


1.ip可以ping通,但是通过ip加端口无法访问服务器部署的nginx页面

问题原因:阿里云服务器部署的若是centos 7 以及7之后的系统,80被防火墙占用(7之前默认不启用),其次需要为服务器配置安全组,这个安全组相当于防火墙,需要将各个软件常用端口释放出来,比如网络访问端口80,443等都需要配置安全规则。


2.安全组配置完成后访问ng配置的页面显示403.此处是因为ng的两个进程一个master一个worker(master用以管理worker),启动用户不同导致的,需要找到自己的ng的配置文件:nginx/conf/nginx.conf 将该文件第一行的 “user nobody;”更改为ng的正常用户,注意一般这行代码是注释掉的,需要把#号删除。


相关文章
|
5月前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
377 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
5月前
|
存储 Linux 开发工具
Linux环境下使用Buildroot配置软件包
使用Buildroot可以大大简化嵌入式Linux系统的开发和维护工作,但它需要对Linux系统和交叉编译有深入的理解。通过上述步骤,可以有效地配置和定制软件包,为特定的嵌入式应用构建高效、稳定的系统。
626 11
|
5月前
|
消息中间件 Kafka Linux
Linux下安装Kafka 3.9.1
本文介绍Kafka 3.9.1版本的安装与配置,包括通过ZooKeeper或KRaft模式启动Kafka。涵盖环境变量设置、日志路径修改、集群UUID生成、存储格式化及服务启停操作,适用于Linux环境下的部署实践。
633 0
|
7月前
|
存储 监控 Linux
Linux环境锁定关键文件防止误删操作流程。
总结以上内容,在Linux环境下锁定重要文档避免误删涉及到多种技术手段与策略组合运作, 包括但不限于利用chatter指挥官固化文档状态至只读模式、运作ACL精准调整访问权利列表、编排自动化流程简
364 20
|
7月前
|
Linux
Linux环境下的UDEV机制及其与守护进程的关联
实际使用时管理员需要熟悉编写合适udev rules去满足特殊需求;同时也需要注意避免编写过度复杂导致无法预料结果rules.UDEVD虽然稳健但错误配置可能导致无法预料问题因此需谨慎处理相关配置工作.
254 16
|
7月前
|
网络协议 关系型数据库 Linux
【App Service Linux】在Linux App Service中安装 tcpdump 并抓取网络包
在App Service for Linux环境中,无法像Windows一样直接使用网络排查工具抓包。本文介绍了如何通过TCPDUMP在Linux环境下抓取网络包,包括SSH进入容器、安装tcpdump、执行抓包命令及下载分析文件的完整操作步骤。
367 5
|
安全 Linux 测试技术
配置Goby工具环境(win,linux,macOS)
配置Goby工具环境(win,linux,macOS)
1592 2
|
10月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
580 11