CentOS7快速配置nginx node mysql8.0
目录:
(一)基础准备
(二)安装node
(三)安装nginx
(四)安装mySql8.0
(五)整体配置
(六)安装PM2守护进程
(一)基础准备
1.1 概述
服务器操作系统为 centos7.4,目的是配置nodejs服务器,用于微信小程序的服务端。
1.2 名词
1. putty : 远程连接linux服务器命令行的工具,如果你在服务器旁边就无需使用了。
本文用于登陆到服务器执行配置命令。
2. FileZilla : 远程连接linux服务器可视化上传文件的工具。
本文用于上传网站文件,及修改配置文件。
3. Nginx : 是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器。
本文中用于单IP配置多个网站。
4. Node.js : 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。
后期的开发软件就基于node
5. MySQL : Mysql是流行的关系型数据库管理系统
6. https: 是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。
https的默认端口是443, 就像http默认端口80一样,使用的时候不用加端口号。
7. websocket : 约定了一个通信的规范,通过一个握手的机制,客户端(浏览器)和服务器(webserver)之间能建立一个类似tcp的连接,从而方便c-s之间的通信。
使用类似 ws://127.0.0.1 连接
8. PM2 node.js的守护进程
(二)安装node
首先连上centos服务器,使用putty或其他的方式。
node安装基本方法就是下载最新版的node压缩包,解压到服务器,建立全局映射软连接。比如可以下载到本地解压后用FileZilla上传到服务器。
以下通过命令行进行安装。
1、wget下载node.js安装包。
wget https://nodejs.org/dist/v9.11.1/node-v9.11.1-linux-x64.tar.xz
// 本文安装node9.11.1版本,如果其他版本可以自己换
2、 解压文件。
tar xvf node-v9.11.1-linux-x64.tar.xz
3、移动文件到 /usr/local/node文件里
mkdir -p /usr/local/node // 新建文件夹
mv /root/node-v9.11.1-linux-x64/* /usr/local/node/ // 将文件移动到/usr/local/node下。
4、到此node和npm只能在 /usr/local/node/bin文件下使用,要想node和npm全局有效,可以通过创建软连接。
ln -s /usr/local/node/bin/node /usr/local/bin/node // 创建node软连接
ln -s /usr/local/node/bin/npm /usr/local/bin/npm // 创建npm软连接
如果文件想换个目录,可以先删除软连接,在创建软连接:
rm -f /usr/local/bin/node
rm -f /usr/local/bin/npm
5、查看node和npm版本
node -v
npm -v
如果返回版本号,就可以确定是安装成功了。node的安装方法有很多,另一种常见的是编译安装,编译安装相对较复杂些,
(三)安装nginx
安装方法有很多,这里是用的yum安装的
// 添加CentOS 7 Nginx yum资源库
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
// 安装最新版
yum install -y nginx
检查nginx是否安装成功
nginx -t // 有下面提示代表安装成功
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
启动nginx
systemctl start nginx.service // 启动nginx
systemctl stop nginx.service // 停止nginx
systemctl restart nginx.service // 重启nginx
systemctl enable nginx.service // 设置开机启动
nginx启动后在浏览器中输入http://外网IP地址,你就可以看到一个nginx页面
(四)安装mySql8.0
MySQL 8.0是自5.7之后的新版本.本文的安装采用yum在线安装的方式,也可以使用编译安装
a)配置MySQL8.0的安装源.
在mysql官网上找到源,打开网址: https://dev.mysql.com/downloads/repo/yum/
进入下一个页面,鼠标指向红色圈住的链接,可以找到对应的地址
搞到源了,就可以执行安装了
sudo rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
//可以跳过wget,yum安装时候会自动下载,如果比较慢,还是先wget吧。
b)安装MySQL 8.0
yum install mysql-server
c)启动Mysql服务.
service mysqld start
d)查看MySQL的状态.
service mysqld status
e)查看mysql为root用户生成的临时密码
grep “A temporary password” /var/log/mysqld.log
使用mysql生成的’root’@’localhost’用户和密码登录数据库,并修改 其密码,具体命令
shell> mysql -uroot -p
mysql> ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘MyNewPass4!’;
修改密码策略:(先要修改临时密码,才能查看密码策略,才能修改为简单密码!!!)
1、查看当前密码策略
show variables like ‘%password%’;
2. 修改密码策略,也可以在/etc/my.cnf文件添加validate_password_policy配置
set global validate_password.length=1; //虽然设置=1,结果也是最小4位,mysql的限制
set global validate_password.policy=0;
3. 修改为简单的的密码
ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘1234’;
4.刷新权限;
flush privileges;
5. 查看认证方式
SELECT host,user,plugin,authentication_string FROM mysql.user;
最主要的是mysql8登录的密码协议发生了变更,使用mysql命令行客户端完全可以登录,之前编写的程序不能登陆,提示错误。显示的意思为“认证协议“错误。
修改认证方式,使用传统的认证
ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘mypass’;
// update mysql.user set authentication_string = password(‘你准备设置的密码’) where user = ‘用户名’;
常用指令:
create database 数据库名;
导入:source /root/wwwroot/Dump20180420.sql; (假设我这里文件在/root/wwwroot/Dump20180420.sql)
注意mysql导出sql文件的时候,将所有表名变成了小写。导入之后可能已有的程序找不到表。
需要 在/etc/my.cnf 文件添加大小写敏感配置
mysql 区分大小写
lower_case_table_names=1 大小写不敏感,表名存储在磁盘是小写的,但是比较的时候是不区分大小写
lower_case_table_names=0 表名存储为给定的大小和比较是区分大小写的
lower_case_table_names=2, 表名存储为给定的大小写但是比较的时候是小写的
最后重启一下MySql服务即可
service mysqld restart
导入数据的时候注意大小写问题 linux将sql中表名变成了小写
而原先设计的mysql数据库中,表名是用大小写来间隔单词的,是大小写敏感(mysql部署在linux上)
(五)整体配置
5.1 配置网站目录
我这里将网站放在了root目录下面,注意修改root目前的权限为755。新建目录及修改权限的操作我是通过FileZilla连接建立的。
在root目录下面建立wwwroot文件夹用于存放网站文件。
在wwwroot目录下面建立www.acctc.com文件夹,
在wwwroot目录下面建立www.open3rd.com文件夹,
这两个文件夹用于放置不同域名的网站内容,后面要配置到nginx里面。
5.2 配置nginx
nginx配置:
nginx配置文件为 /etc/nginx/nginx.conf
server {
listen 80;
location / {
proxy_pass http://127.0.0.1:3000; # 本地node启动的端口为3000
}
}
将proxy_pass 的值改为 http://127.0.0.1:3000, 3000的端口号为本地node启动的端口号。
重启nginx
systemctl restart nginx.service
在浏览器中输入http://IP地址,进行测试
(六)安装PM2守护进程
npm install pm2 -g
建立软连接
sudo ln -s /usr/local/node/bin/pm2 /usr/bin/pm2
开始运行
pm2 start /root/wwwroot/www.acctc.com/app.js
查看列表
pm2 list
转发申明:
本文转自互联网,由小站整理并发布,在于分享相关技术和知识。版权归原作者所有,如有侵权,请联系本站 top8488@163.com,将在24小时内删除。谢谢