linux内网(无法连接外网)服务器安装nginx并部署vue网站

内网(无法连接外网)服务器安装nginx并部署vue网站

0:如果使用(Xshell)登录linux无法传输文件——————1:检查是否切换了root权限。2:系统缺少lrzsz

1:
sudo 想要的指令          //执行具体的指令
sudo -s                      //切换root身份


2:
wget https://ohse.de/uwe/releases/lrzsz-0.12.20.tar.gz
tar -xvf lrzsz-0.12.20.tar.gz
cd lrzsz-0.12.20
./configure
make
make install
ln -s /usr/local/bin/lrz /usr/bin/rz
ln -s /usr/local/bin/lsz /usr/bin/sz

1:解决缺少gcc、pre-devel、openssl-devel、zlib-devel等依赖的问题

无法连接外网的内网中或服务器不能连接网络的环境下,因为缺少gcc、pre-devel、openssl-devel、zlib-devel等依赖,所以无法使用yum等方式安装,所以本文给出一种适用于内网环境或离线环境的Nginx安装方法。

1、查看自己想要安装Nginx的linux服务器的版本号
cat /etc/redhat-release

2、下载相同版本的linux.iso文件

镜像下载地址:http://vault.centos.org/7.7.1908/isos/x86_64/

下载完成后,按如下图所示在iso文件中找到Packages文件夹中的文件

在Packages文件夹中找出以下文件(共25个)

autogen-libopts-5.18-5.el7.x86_64.rpm
cpp-4.8.2-16.el7.x86_64.rpm
gcc-4.8.2-16.el7.x86_64.rpm
glibc-devel-2.17-55.el7.x86_64.rpm
glibc-headers-2.17-55.el7.x86_64.rpm
kernel-headers-3.10.0-123.el7.x86_64.rpm
keyutils-libs-devel-1.5.8-3.el7.x86_64.rpm
krb5-devel-1.11.3-49.el7.x86_64.rpm
libcom_err-devel-1.42.9-4.el7.x86_64.rpm
libmpc-1.0.1-3.el7.x86_64.rpm
libselinux-devel-2.2.2-6.el7.x86_64.rpm
libsepol-devel-2.1.9-3.el7.x86_64.rpm
libverto-devel-0.2.5-4.el7.x86_64.rpm
mpfr-3.1.1-4.el7.x86_64.rpm
ntp-4.2.6p5-18.el7.centos.x86_64.rpm
ntpdate-4.2.6p5-18.el7.centos.x86_64.rpm
openssl098e-0.9.8e-29.el7.centos.x86_64.rpm
openssl-1.0.1e-34.el7.x86_64.rpm
openssl-devel-1.0.1e-34.el7.x86_64.rpm
openssl-libs-1.0.1e-34.el7.x86_64.rpm
pcre-devel-8.32-12.el7.x86_64.rpm
pkgconfig-0.27.1-4.el7.x86_64.rpm
tcl-8.5.13-4.el7.x86_64.rpm
zlib-1.2.7-13.el7.x86_64.rpm
zlib-devel-1.2.7-13.el7.x86_64.rpm

找出以上25个rpm包后将其上传至linux服务器,执行以下代码

rpm -Uvh ./*.rpm --nodeps --force

在上传以上25个rpm包的文件夹中执行以上代码,便可以安装以上rpm包
至此,gcc、pre-devel、openssl-devel、zlib-devel等依赖缺失的问题解决。

安装完成后可以使用gcc -v g++ -v 指令查看环境是否安装成功。

2:安装nginx

因为内网和离线状态等无法使用yum等指令,所以需要下载nginx安装包至本地,再上传至linux服务器,
可以在http://nginx.org/en/download.html
下载Nginx相关版本至本地,之后上传至linux服务器root文件夹下(我将安装包放在了 /usr/local 目录下)

之后在存放安装包的文件夹下,执行以下代码解压压缩包

例:tar -zxvf nginx-1.14.2.tar.gz

进入解压的目录中

cd 文件名
例:cd nginx-1.14.2

执行文件,检查配置文件是否生效

./configure

执行以下两行代码分别进行编译和安装依赖

make
make install

启动nginx
进入cd /usr/local/nginx/sbin
执行ls 可以看到nginx

执行 ./nginx 便可启动nginx

查看nginx是否启动
ps -aux | grep nginx

若nginx已启动,那么确认防火墙关闭后,便可以访问nginx了 (一般初始地址为 http://localhost:80 还要确认本服务器上没有其他已经安装的程序在占用80端口,如果已经占用,则需要更改成其他端口)

1.firewalld的基本使用
启动:     systemctl start firewalld
查状态: systemctl status firewalld
停止:    systemctl stop firewall
禁用:    systemctl disable firewalld
在开机时启用一个服务:systemctl enable firewalld.service
在开机时禁用一个服务:systemctl disable firewalld.service
查看服务是否开机启动:systemctl is-enabled firewalld.servic
查看已启动的服务列表:systemctl list-unit-files|grep enabled
查看启动失败的服务列表:systemctl --failed
2.查询端口是否开放: firewall-cmd --query-port=80/tcp
开放80端口:  firewall-cmd --permanent --add-port=80/tcp
移除端口:firewall-cmd --permanent --remove-port=8080/tcp
查看开放了那些端口: firewall-cmd --list-ports
重启防火墙(修改配置后要重启防火墙):  firewall-cmd --reload

重启nginx

验证nginx配置文件是否正确,

进入nginx安装目录sbin下,输入命令./nginx -t,即以下三行命令
cd /usr/local/nginx/sbin
ls
./nginx -t

重启nginx服务
方法一:进入nginx可执行目录sbin下,输入命令./nginx -s reload 即可

cd /usr/local/nginx/sbin
./nginx -s reload

方法二:查找当前nginx进程号,然后输入命令:kill -HUP 进程号 实现重启nginx服务

ps -ef|grep nginx
kill -HUP 进程号

3:将网站部署至linux服务器

nginx配置中常见错误见本文最后

1:将vue前端项目build好, 一般是dist文件夹,将dist文件夹压缩成tar格式的压缩包后上传至linux服务器(7-zip可以打包成这种格式),并记住压缩包的存放路径

2:将第一步上传的压缩包解压
tar -xvf home_wh.tar

3:修改nginx.conf配置文件

进入相应文件夹
cd /usr/local/nginx/conf

编辑nginx.conf
vim nginx.conf

即可进入nginx.conf中,其中:
进入编辑模式后:
i:进入编辑模式

“#”+文本 为注释

ESC退出编辑模式
q打开命令行
wq!(注意大小写)之后点击Enter即可保存退出

以下为nginx中原始代码(去掉注释的版本见下面)

user  nobody; 
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;
    
        charset utf-8;
    
        #access_log  logs/host.access.log  main;
    
        location / {
            root   /root/www/;          ## 设置的地方
            index  index.html index.htm;
        }
                #error_page  404              /404.html;
    
            # redirect server error pages to the static page /50x.html
            #
            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }
    
            # proxy the PHP scripts to Apache listening on 127.0.0.1:80
            #
            #location ~ \.php$ {
            #    proxy_pass   http://127.0.0.1;
            #}
    
            # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
            #
            #location ~ \.php$ {
            #    root           html;
            #    fastcgi_pass   127.0.0.1:9000;
            #    fastcgi_index  index.php;
            #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            #    include        fastcgi_params;
            #}
    
            # deny access to .htaccess files, if Apache's document root
            # concurs with nginx's one
            #
            #location ~ /\.ht {
            #    deny  all;
            #}
        }
}

去注释版

user  nobody;  #初始一般为nobody,改为root即可
worker_processes  1;

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  65;

    server {
        listen       80;     #监听的端口,默认为80,如果其他程序也在使用80端口,则会产生冲突,将这里的80改为其他端口即可解决。如:8082
        server_name  localhost;    #默认为localhost,也可改为服务器的ip地址
    
        charset utf-8;
    
        #access_log  logs/host.access.log  main;
    
        location / {
            root   /root/www/;          ## 上传的dist的文件的位置
            index  index.html index.htm;  #启动的文件位置,可以是一个,也可以是多个
        }

            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }
        }
}

修改完后重启nginx服务,即可更新。

常见问题解决

1:配置后无法访问页面 Nginx报错:403 Forbidden

posted @ 2021-09-09 16:22  青砖黛瓦  阅读(1891)  评论(0编辑  收藏  举报