在Linux上部署.net Core 步骤以及遇到的一些问题

Linux安装部署手册

 

 

一、安装.NET Core SDK

 

centos 7 系统命令为:

sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm

sudo yum install dotnet-sdk-3.1

 

 

CentOS 8 系统命令为:

 

sudo dnf install dotnet-sdk-3.1

 

二、安装GDIP

GDIP命令如下

yum install libgdiplus-devel

 

 

 

三、安装MySQL

1.linux操作系统版本和系统内核版本

cat /etc/redhat-release

uname -r

 

2.选择对应版本下载rpm包

官网下载地址:MySQL5.7下载地址

我已经打包了,也可以自行下载,MySQL最低版本5.7

 

3.解压rpm包并安装

解压rpm包并查看

#选择官网下的 tar上传 至服务器

 

#进入上传目录,进行解压(该命令与你下载的文件名称有关,请注意)

tar xf mysql-5.7.17-1.el7.x86_64.rpm-bundle.tar

 

安装所需要组件

注意:安装过程中会发现报错,因为centos系统自带mariadb,因此要卸载自带的 mariadb才能够成功安装

卸载mariadb

#查看系统的 mariadb

rpm -qa|grep mariadb

# 清除原有系统的  mariadb

# mariadb-libs-5.5.68-1.el7.x86_64】每一个系统都不一样

# --nodeps 结尾必须

rpm -e mariadb-libs-5.5.68-1.el7.x86_64 --nodeps

 

安装组件

#只需要安装部分组件 (需要安装)该命令与你压缩包解压出来的文件名称需要一致,如果你用的是我打包的Mysql文件按照这些运行即可,否则需要更改一下名称

rpm -ivh mysql-community-common-5.7.17-1.el7.x86_64.rpm  

rpm -ivh mysql-community-client-5.7.17-1.el7.x86_64.rpm  

rpm -ivh mysql-community-server-5.7.17-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-5.7.17-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-compat-5.7.17-1.el7.x86_64.rpm

 

#组件暂留

mysql-community-embedded-compat-5.7.17-1.el7.x86_64.rpm

mysql-community-embedded-devel-5.7.17-1.el7.x86_64.rpm     

mysql-community-server-minimal-5.7.17-1.el7.x86_64.rpm

mysql-community-test-5.7.17-1.el7.x86_64.rpm

mysql-community-devel-5.7.17-1.el7.x86_64.rpm     

mysql-community-embedded-5.7.17-1.el7.x86_64.rpm  

mysql-community-minimal-debuginfo-5.7.17-1.el7.x86_64.rpm

 

 

安装组件异常图解:

问题1:

 

#补齐libaio环境

yum install libaio

问题2:

 

#补齐perl环境

yum install perl

问题3:

 

#补齐net-tools环境

yum install net-tools

 

安装成功示例图

 

安装之后的目录

/var/lib/mysql

配置文件

/etc/my.cnf

 

 

4. 当组件安装完成,需要进行 初始化mysql

mysqld --initialize --user=mysql

 

 

 

5.启动mysql服务并查看状态

#进行启动

systemctl start mysqld.service

#查看mysql 状态

systemctl status mysqld.service

 

 

5. 查看初始密码

 

grep "password" /var/log/mysqld.log

 

 

6.根据初始密码启动mysql并重置密码

启动mysql

#登录

mysql -u root -p

#输入密码

 

 

重置密码ROOT为用户名 123456 这一块是密码  

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

 

 

7.设置远程登录无需求可不设置

## 设置外网可访问的 root账号

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123123' WITH GRANT OPTION;

## 刷新

FLUSH PRIVILEGES;  

 

 

8.修改mysql语言lower_case_table_names=1  这条配置一定要加的

注意:设置好远程登录后MySQL基本已安装完成,但在使用数据库创表添加数据时却会发现,当添加的数据是字符时,此时就会因为编码错误导致添加失败,所以我们就要修改mysql的默认语言,将它们设置成utf-8的编码格式。(如果无需修改编码格式可不用配置,)

进入my.cnf文件

#打开配置文件

vim /etc/my.cnf

 

#添加以下语句,并保存(这些是设置编码,无需编码可以不需要)

[client]

default-character-set=utf8

 

[mysqld]

character-ser-server=utf8

collation-server=utf8_general_ci

 

#在[mysqld]节点下,加入该设置(无视大小写,必须加):

lower_case_table_names=1

 

 

保存后重启服务并进入mysql

service mysqld restart

 

 

9. 设置新用户以及权限

登录数据库

mysql -u root -p

 

SET GLOBAL log_bin_trust_function_creators = 1;

 

创建新用户

CREATE USER '用户名'@'允许的主机' IDENTIFIED BY '密码';

 

CREATE USER 'db_yuemintou'@'%' IDENTIFIED BY 'db_yuemintou123!@#';

授权

GRANT 权限类型 ON 数据库名.表名 TO '用户名'@'允许的主机'

 

GRANT ALL ON *.* TO 'db_yuemintou'@'%';

 

刷新权限

flush privileges;

 

 

 

退出mysql

exit

 

10. 还原数据库

#切换到mysql数据备份还原路径  /usr/share/mysql

#切换CD之后需要把mysql脚本上传到该目录

cd /usr/share/mysql

 

#还原数据库操作

登录Mysql

mysql -u root -p

 

show databases;

#你要还原什么数据库就建立什么数据库名

create database db_yuemintou;

#切换到你刚才新建的数据库

use db_yuemintou;

#导入数据(该名称与你上传的Mysql脚本名称需要一致)

source db_yuemintou.sql;

#再次出现“mysql>”就说明成功了

 

 

 

 

四、安装NGINX代理服务器

 

#切换到home文件夹

cd /home

#下载资源文件

wget http://nginx.org/download/nginx-1.16.1.tar.gz

#解压

tar -zxvf nginx-1.16.1.tar.gz

#进入目录

cd nginx-1.16.1

#添加模块

./configure --with-http_stub_status_module --with-http_ssl_module   

#编译

make

#安装

make install   

#进入目录

cd /usr/local/nginx/sbin

#启动NGINX

./nginx  

#重启命令

./nginx -s reload

#将  nginx.service  放置   cd /etc/systemd/system (我会一起打包,该服务是让nginx随着系统一起启动)

#设置nginx 自启动

/usr/local/nginx/sbin/nginx -s quit

systemctl enable nginx

systemctl start nginx.service

#注意:每次修改配置后需要重载一下配置

 

#nginx代理配置路径 /usr/local/nginx/conf

#注: 日志路径必须存在 如不存在则 需要运行不起来

server

    {

         listen 80;

 

         server_name localhost;

         location / {

         proxy_pass http://localhost:3000;

         proxy_http_version 1.1;

         proxy_set_header Upgrade $http_upgrade;

         proxy_set_header Connection keep-alive;

         proxy_set_header Host $host;

         proxy_cache_bypass $http_upgrade;

    }

    

         location /upload {

         root  /www/wwwroot/fontEnd/;

    }

 

         access_log  /www/wwwlogs/access.log;

    }

    

 server

    {

         listen 8003;

         server_name localhost;

         location / {

         proxy_pass http://localhost:8080;

         proxy_http_version 1.1;

         proxy_set_header Upgrade $http_upgrade;

         proxy_set_header Connection keep-alive;

         proxy_set_header Host $host;

         proxy_cache_bypass $http_upgrade;

    }

        access_log  /www/wwwlogs/access.log;

    }

 

 

#重启nginx

service nginx restart

 

 

五、安装Supervisor守护进程

#执行epel-release

sudo yum -y install epel-release

#安装Supervisor

sudo yum -y install supervisor

#通过配置文件来启动supervisor

sudo supervisord -c /etc/supervisord.conf

#启动supervisorctl

sudo supervisorctl -c /etc/supervisord.conf

#查看supervisor 版本

version

#将配置文件(我会一起打包,配置文件内的日志路径必须存在否则运行不起来)放置目录

cd /etc/supervisord.d

 

 

#启动supervisor

#启动方式1:通过supervisor服务端使用配置文件启动

sudo supervisord -c /etc/supervisord.conf

 

#启动方式2:通过客户端命令行启动

#先启动supervisorctl

sudo supervisorctl -c /etc/supervisord.conf

#重新加载配置文件

reload

#查看运行的状态

status

 

#错误一:

Error: Another program is already listening on a port that one of our HTTP servers is configured to use.  Shut this program down first before starting supervisord.

 

#解决方法:

ps aux | grep supervisord

kill - 9  进程ID

 

#错误二:

Unlinking stale socket /var/run/supervisor/supervisor.sock

 

#解决方法:

unlink /var/run/supervisor/supervisor.sock

 

#Supervisor开机自启动(配置会一起打包)

#进入system目录 将 supervisor.service文件 放置这个目录

cd /usr/lib/systemd/system

 

#启动服务  注:启动服务之前要先关闭

supervisorctl stop all

systemctl enable supervisord

 

#验证一下是否为开机启动

systemctl is-enabled supervisord

 

 

#关于一些supervisorctrl操作

1、更新新的配置到supervisord

supervisorctl update

2、重新启动配置中的所有程序

supervisorctl reload

3、启动某个进程(program_name=你配置中写的程序名称)

supervisorctl start program_name

4、查看正在守候的进程

supervisorctl

5、停止某一进程 (program_name=你配置中写的程序名称)

pervisorctl stop program_name

6、重启某一进程 (program_name=你配置中写的程序名称)

supervisorctl restart program_name

7、停止全部进程

supervisorctl stop all

8、重载全部进程

supervisorctl restart all

 

六、安装nodejs 环境 

#进入home目录

cd /home       

创建node文件夹

mkdir node

#进入node文件夹

cd node

#下载资源文件

wget -c https://npm.taobao.org/mirrors/node/v14.18.1/node-v14.18.1-linux-x64.tar.xz

#解压文件

tar -xvf node-v14.18.1-linux-x64.tar.xz

#改名

mv node-v14.18.1-linux-x64 nodejs

#建立软连接 (注:目录路径需要一致 否则失败)

ln -fs /home/node/nodejs/bin/node /usr/local/bin/

ln -fs /home/node/nodejs/bin/npm /usr/local/bin/

#查看nodenpm版本号

node -v

npm -v

#安装pm2

npm install pm2 -g

#配置全局映射(注:目录路径需要一致 否则失败)

ln -fs /home/node/nodejs/bin/pm2  /usr/local/bin/pm2

#进入前端项目的根路径(注:我放置的是/www/wwwroot/fontEnd  你也可以自行放置,不过命令路径需要修改)

cd /www/wwwroot/fontEnd

npm i

#启动项目

pm2 start

#保存当前项目列表

pm2 save  

#设置为开机启动

pm2 startup

七、防火墙相关命令

#开启防火墙命令

systemctl start firewalld.service

#重启防火墙命令

firewall-cmd --reload 或者 service firewalld restart

#禁用防火墙命令

systemctl stop firewalld

#防火墙永久开启端口命令

#例如我开启8002端口

firewall-cmd --zone=public --add-port=8002/tcp --permanent

#重载防火墙

firewall-cmd --reload

八、关于配置的下载

 这是上文中需要的一些配置 mysql安装命令需要严格按照mysql的名字来

百度网盘链接: https://pan.baidu.com/s/1FQsggqiy0y0DqvS7b_o_Ew 提取码: aawt 复制这段内容后打开百度网盘手机App,操作更方便哦

posted @ 2022-07-28 10:08  G_L。  阅读(83)  评论(0编辑  收藏  举报