100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > 云服务器 Linux上安装xampp 搭建node服务 云服务器Firewalld iptables nginx反向代理

云服务器 Linux上安装xampp 搭建node服务 云服务器Firewalld iptables nginx反向代理

时间:2021-12-30 01:33:42

相关推荐

云服务器 Linux上安装xampp 搭建node服务 云服务器Firewalld iptables nginx反向代理

目录

写在前面的前期准备下载xampp:xampp安装步骤1、首先链接远程linux服务器2、xshell终端执行安装命令3、启动:xampp服务4、访问数据库,修改数据库密码安装守护进程pm2服务器下启动,node服务linux上的node.js的网站是否正常运行,端口是否正常监听`curl`服务防火墙nginx代理nginx反向代理,附带二级域名解析nginx配置 https 转 node 服务linux查看自己的ip地址,注意:查询到得是私有ip信息,公网ip再网站上实例中查看windows开启telnet客户端来验证ip和端口是否通**windows开发`telnet`**`telnet ip 端口号`

写在前面的

如果说将后端api代码部署到云服务器,并使用域名访问接口,那么需要一些前期准备;这里需要提一下的是,因为服务器有一个外网ip,因此可以在通过外网ip访问到服务器启动的服务;

前期准备

云服务器,注册域名,备案,域名解析(当然没有域名也是可以的,可以通过外网ip访问;但,例如小程序访问api就必须使用https://域名/api,才能访问,这是小程序限制的)

下载xampp:

下载安装包,官网链接:/zh_cn/download.html ;根据服务器的linux系统/位数下载对应版本查询linux版本:

cat /proc/version

uname -a

关于安装包下载被墙网速限制或无法下载,可以私我,我发给你们,linux和windows、os和版本都有的;

xampp安装步骤

1、首先链接远程linux服务器

这里使用的免费版xshell链接服务器;来到目录root/tools下面,可以新建目录或者其他目录;但需要确保有去操作权限,不然会提示(Text file busy)文本文件忙,无法操作或安装等;

来到目录:root/tools

cd /root/tools

下载:xampp

wget /xampp-files/7.2.30/xampp-linux-x64-7.2.30-0-installer.run

如果提示链接失败,无法下载,那么办法是: 先把安装包下载到本地,然后使用fileZilla工具连接服务器,用工具上传文件到目录root/tools下;什么安装包下载被墙?私我~

2、xshell终端执行安装命令

首先赋予权限,如果没有权限不能安装:

chmod -R 755 xampp-linux-x64-7.2.30-0-installer.run

再执行安装:

./xampp-linux-x64-7.2.30-0-installer.run

安装过程,就是直接y,回车,如此循环,,

xampp默认安装在/opt/lampp目录下

3、启动:xampp服务

启动:

/opt/lampp/lampp start

或,如在opt/lampp目录下直接执行可以

.lampp start

停止:

/opt/lampp/lampp stop

查看状态

/opt/lampp/lampp status

重启:

/opt/lampp/lampp restart

重要:如果启动失败,可能服务器启动了其他服务,占用了,例如 nginx服务,需要先停止nginx服务sudo systemctl stop nginx

xampp启动成功之后,通过公网ip访问xampp启动页,http://公网ip/dashboard/

4、访问数据库,修改数据库密码

先进入数据库

如果不能进入,提示:

那么,修改phpMyAdmin配置文件,配置文件目录/opt/lampp/etc/extra,一会说一下,各个配置文件对应文件;

修改如下:也就是将Require local改成Require all granted

然后再进入phpMyAdmin,进来之后修改密码;

然后输入密码,右下角执行就可以了;

修改密码之后,发现无法连接数据了,因为数据库配置文件中的登录信息没有写上密码,所以登录失败;解决:打开配置文件,写上密码就可以。

配置文件目录:/opt/lampp/phpmyadmin

$cfg['Servers'][$i]['password'] = '';

修改成刚刚更改的密码;

这样就能正常连接数据库了;

安装守护进程pm2

运行命令全局安装

npm install pm2 -g

在linux下,安装之后运行命令 pm2 list,发现无法正常执行提示;

pm2 list

发现提示:

-bash: pm2: command not found

这是因为linux不会想windows一样全局配置,需要手动配置一下;

①、echo $PATH一下路径

②、然后找到pm2的安装路径,一般在npm install pm2 -g的时候会提示路径;我的在 /usr/local/nodejs/bin 路径下

重要执行:注意检查的路径

ln -s /usr/local/nodejs/bin/pm2 /usr/local/bin/

然后:pm2 list

pm2可以正常使用了;一切准备就绪只差公网访问node服务。

服务器下启动,node服务

代码:

// index.jsconst http = require('http');const hostname = '0.0.0.0';const port = 9000;const server = http.createServer((req, res) => {res.statusCode = 200;res.setHeader('Content-Type', 'text/plain');res.end('Hello World\n');});server.listen(port, hostname, () => {console.log(`Server running at http://${hostname}:${port}/`);});

启动:

pm2 start index.js

linux上的node.js的网站是否正常运行,端口是否正常监听curl

curl localhost:9000

or

curl 公网ip:9000

服务防火墙

服务器,linux系统配置端口号的坑!!!服务器防火墙配置!!!

nginx代理

nginx反向代理,附带二级域名解析

# nginx反向代理upstream a0127 {server 127.0.0.1:9000; # 这里的端口号写你node.js运行的端口号,也就是要代理的端口号,我的项目跑在8081端口上keepalive 64;}# 附带二级域名使用()server {listen 9001; #这里的端口号是你要监听的端口号server_name 47.104.67.xxx ; # 这里是你的服务器名称,也就是别人访问你服务的ip地址或域名,可以写多个,用空格隔开location / {proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_set_header X-Nginx-Proxy true;proxy_set_header Connection "";proxy_pass http://a0127; # 这里要和最上面upstream后的应用名一致,可以自定义}}

nginx配置 https 转 node 服务

# nginx反向代理upstream a0127 {server 127.0.0.1:9000; # 这里的端口号写你node.js运行的端口号,也就是要代理的端口号,我的项目跑在9000端口上keepalive 64;}server {listen 443 ssl; #SSL协议访问端口号为443。此处如未添加ssl,可能会造成Nginx无法启动。server_name ; #将localhost修改为您证书绑定的域名,例如:。root html;index index.html index.htm;ssl_certificate /etc/letsencrypt/live//fullchain.pem; # managed by Certbot#将domain name.pem替换成您证书的文件名。ssl_certificate_key /etc/letsencrypt/live//privkey.pem; # managed by Certbot#将domain name.key替换成您证书的密钥文件名。ssl_session_timeout 5m;ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; #使用此加密套件。ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #使用该协议进行配置。ssl_prefer_server_ciphers on;# 443转 静态目录# location / {#root /var/www/hc; #站点目录。#index index.html index.htm;# }# 443转node服务location / {proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_set_header X-Nginx-Proxy true;proxy_set_header Connection "";proxy_pass http://a0127; # 这里要和最上面upstream后的应用名一致,可以自定义}}# 提高权重 的请求转向到 server {listen 443;server_name ;rewrite ^ permanent;}

linux查看自己的ip地址,注意:查询到得是私有ip信息,公网ip再网站上实例中查看

ifconfig

windows开启telnet客户端来验证ip和端口是否通

windows开发telnet

telnet ip 端口号

感谢,参考如下:

/putao2062/article/details/79688020

/Ghost_hell/article/details/54915739

/developer/article/1398311

/u/2252639/blog/1798667

/quincylk/article/details/50562399

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。