Centos 7 中 部署 asp.net core 3.0 + nginx + mongodb 的一些新手简单入门,非docker

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

Centos 7 中 部署 asp.net core 3.0 + nginx + mongodb 的一些新手简单入门,非docker

启天   2020-03-03 我要评论
[TOC] ------ **正文开始** # 零.准备工作 由于以前一直部署在Windows系统下,,这次领导说要测试下部署到Centos上,测试了一个下午,,踩了不少的坑,,因此记录下来 主要参考了几篇文章: https:/https://img.qb5200.com/download-x/docs.microsoft.com/zh-twhttps://img.qb5200.com/download-x/dotnet/core/install/linux-package-manager-centos7 **//介绍怎么安装core运行时的** https:/https://img.qb5200.com/download-x/docs.microsoft.com/zh-tw/aspnet/core/host-and-deploy/linux-nginx?view=aspnetcore-3.1 **//最重点的文章了,大部分都在这里** https://blog.csdn.net/qq_24232123/articlehttps://img.qb5200.com/download-x/details/79781527 //这篇主要是防火墙的配置指令,,比较懒得背 https:/https://img.qb5200.com/download-x/docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/ **//mongodb的安装部署** https:/https://img.qb5200.com/download-x/docs.mongodb.com/manual/reference/configuration-options/ **//mongodb的配置** 总共有几条常用的命令: ```bash systemctl enable xxxxxx #允许一个服务自动启 systemctl start xxxx #启动一个服务 systemctl stop xxxx #停止一个服务 firewall-cmd --add-port=666/tcp --permanent #防火墙开放一个端口 systemctl daemon-reload #修改服务文件后,用来强制重新加载的 yum install xxxx #安装软件 nano xxxx #编辑文件 chown -R mongod:xxx #某个目录授权给mongod用户 mkdir -p /usr/website/api #新建目录 ``` **需要下载两个软件,都是免费软件,放心下载** https://www.putty.org/ 中的 PuTTY,,Bitvise SSH Client ,,PuTTY用来做远程终端命令行的,另外一个是用来上传文件的 **安装nano** ```bash     yum install nano ``` # 一.部署Mongodb ## 1.安装Mongodb ```bash     sudo nano /etc/yum.repos.d/mongodb-org-4.2.repo ```     粘贴入,保存后退出 ```yaml [mongodb-org-4.2]     name=MongoDB Repository     baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/     gpgcheck=1 enabled=1     gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc ``` ```bash sudo yum install -y mongodb-org ``` ##  2.创建mongodb的数据目录 ```     mkdir -p /usr/websitehttps://img.qb5200.com/download-x/databse/mongodbhttps://img.qb5200.com/download-x/db     mkdir -p /usr/websitehttps://img.qb5200.com/download-x/databse/mongodb/log ``` ## 3.设置目录权限 ```bash     sudo chown -R mongod:mongod /usr/websitehttps://img.qb5200.com/download-x/databse/mongodbhttps://img.qb5200.com/download-x/db     sudo chown -R mongod:mongod /usr/websitehttps://img.qb5200.com/download-x/databse/mongodb/log ``` ## 4.设置mongodb启动 ```bash     sudo systemctl enable mongod.service    ``` ## 5.修改mongodb的配置文件 ```bash     sudo nano /etc/mongod.conf     修改storage下的dbPath = /usr/websitehttps://img.qb5200.com/download-x/databse/mongodbhttps://img.qb5200.com/download-x/db #不带/结尾     修改net 下的 port = #新的mongodb端口号           bind= 0.0.0.0 #允许远程连接 ``` ##  6.启动Mongodb服务 ```bash     sudo systemctl start mongod.service     sudo systemctl status mongod.service ``` # **二.安装.net core的运行时**: ```bash sudo rpm -Uvh http://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm sudo yum install aspnetcore-runtime-3.0    sudo yum install dotnet-runtime-3.1 ``` # 三.新建web项目的文件夹 ```bash mkdir -p /usr/website/api ```   然后使用 Bitvise SSH Client 把项目站点文件上传到文件夹下   上传成功后,使用 dotnet xxx.web.dll 试试看项目能不能启动,如果提示类似下面的,就表示成功了 ![img](https://img2020.cnblogs.com/i-beta/242360/202003/242360-20200303013657010-956662075.png) # 四.创建站点自动启动的服务 ##   1.创建服务文件 ```bash     sudo nano /etc/systemd/system/kestrel-api.service ```     内容编辑中,粘贴入:   ```yaml [Unit]     Description=Centos RTU Api     [Service]     WorkingDirectory=/usr/website/api #工作目录     #调用的,由于非docker,因此端口号都是共用的,所以core 3.x 使用 --urls 设置了端口号,有一个坑就是,在命令行下,--url= 后面可以使用双引号,,     #但是在这里不能,加了双引号就报错     ExecStart=/usr/binhttps://img.qb5200.com/download-x/dotnet /usr/website/api/xxx.Web.dll --urls=http://*:5123     Restart=always     # Restart service after 10 seconds if the dotnet service crashes:     RestartSec=10     KillSignal=SIGINT     SyslogIdentifier=dotnet-example     User=root #这个是使用的用户,如果非root,则先创建用户,然后把文件夹的权限赋给所使用的用户     Environment=ASPNETCORE_ENVIRONMENT=Production #这是设置运行环境     Environment=DOTNET_PRINT_TELEMETRY_MESSAGE=false     [Install]     WantedBy=multi-user.target ``` ## 2.注册服务 ```bash     sudo systemctl enable kestrel-api.service     sudo systemctl start kestrel-api.service     sudo systemctl status kestrel-api.service ``` ## 3.命令行下使用 ps -ef    看到有这条: ![img](https://img2020.cnblogs.com/i-beta/242360/202003/242360-20200302180623668-492277549.png) ​ 就表示运行起来了   使用 ```bash curl http://localhost:5000 ``` 看看有没有返回值,并且返回的是不是正确的   如果无法正确启动,可以使用微软站点中介绍的: ```bash sudo journalctl -fu kestrel-api.service ```   在日志中,尽量排查出什么问题,一般的话,如果在第二步中,能正常运行的话,那么大部分情况下,程序上就没什么问题,主要是一些目录权限之类的问题     因为测试的时候是使用root,所以没什么目录权限上的问题, # **五.处理nginx** ## 1.安装nginx ```bash    yum install nginx ``` ## 2.配置站点 ```bash     cd /etc/nginx     nano nginx.conf ```   在 server 段下 再新增一段 ```nginx server { listen 8081; #监听8081端口 server_name x.x.x.x:8081; #这里我需要绑定非80端口 location /{ proxy_pass http://localhost:5123; #反向代理到我们刚才指定的--urls 参数的端口号 proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection keep-alive; proxy_set_header Host $http_host; #这个与微软上的不同, 微软上写的是 $host 这个的话,在重定向的时候,会把端口号忽略掉,$http_host会带上端口号 proxy_cache_bypass $http_upgrade; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } ``` # 六.开放防火墙端口 ​ `firewall-cmd --add-port=8081/tcp --permanent`  如果提示错误,请参考最上面的文章链接,如果还是不能访问,请检查云服务器的安全组是否有打开对应的端口号 # 七.有几个小问题需要注意一下 ## 1.重定向的问题:   如果是非80端口的,,需要在程序里重定向的话,一定要在nginx中,配置站点的时候,用 `proxy_set_header Host $http_host` ,,如果按照微软上的用 $host的话,重定向的时候,端口号会被去掉 ## 2.绘图的问题,如果有调用到System.DrawingCore之类的绘图组件的时候,记得使用下面的命令安装绘图库 ​ `sudo yum install libgdiplus` 否则会报找不到 libgdiplus 的错误 ------

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们