Centos 7 中 部署 asp.net core 3.0 + nginx + mongodb 的一些新手簡單入門,非docker



正文開始

零.准備工作

由於以前一直部署在Windows系統下,,這次領導說要測試下部署到Centos上,測試了一個下午,,踩了不少的坑,,因此記錄下來

主要參考了幾篇文章:
https://docs.microsoft.com/zh-tw/dotnet/core/install/linux-package-manager-centos7 //介紹怎么安裝core運行時的
https://docs.microsoft.com/zh-tw/aspnet/core/host-and-deploy/linux-nginx?view=aspnetcore-3.1 //最重點的文章了,大部分都在這里
https://blog.csdn.net/qq_24232123/article/details/79781527 //這篇主要是防火牆的配置指令,,比較懶得背
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/ //mongodb的安裝部署
https://docs.mongodb.com/manual/reference/configuration-options/ //mongodb的配置

總共有幾條常用的命令:

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用來做遠程終端命令行的,另外一個是用來上傳文件的,特別建議安裝 Bitvise SSH Client,能直接打開文件管理器,后續的修改配置文件的操作,可以直接edit,然后用本機的記事本修改后,自動上傳,比在命令行下編輯配置文件,方便許多

安裝nano

    yum install nano

一.部署Mongodb

0.創建對應用戶

    adduser mongod    #添加一個mongod用戶專門跑mongodb的

1.安裝Mongodb

    sudo nano /etc/yum.repos.d/mongodb-org-4.2.repo

    粘貼入,保存后退出

	  [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
	   sudo yum install -y mongodb-org

2.創建mongodb的數據目錄

    mkdir -p /usr/website/database/mongodb/db
    mkdir -p /usr/website/database/mongodb/log

3.設置目錄權限

    sudo chown -R mongod:mongod /usr/website/database/mongodb/db
    sudo chown -R mongod:mongod /usr/website/database/mongodb/log
       sudo chown -R mongod:mongod /opt/mongo  #mongodb的安裝路徑,給新用戶賦權可以訪問

4.設置mongodb啟動

    sudo systemctl enable mongod.service   

5.修改mongodb的配置文件

    sudo nano /etc/mongod.conf
    修改storage下的dbPath = /usr/website/database/mongodb/db #不帶/結尾
    修改net 下的 port = #新的mongodb端口號
          bind= 0.0.0.0 #允許遠程連接

6.啟動Mongodb服務

    sudo systemctl start mongod.service
    sudo systemctl status mongod.service

備注:如果是自己編譯的arm版的mongodb的話,會缺少mongod.service和mongod.conf兩個文件,可以復制下面的文本,自己創建一個

mongod.service 文件,放在 /etc/systemd/system 下

[Unit]
Description=MongoDB Database Server
Documentation=https://docs.mongodb.org/manual
After=network.target

[Service]
User=mongod
Group=mongod
Environment="OPTIONS=-f /etc/mongod.conf"
EnvironmentFile=-/etc/sysconfig/mongod
ExecStart=/opt/mongo/bin/mongod $OPTIONS
ExecStartPre=/usr/bin/mkdir -p /var/run/mongodb
ExecStartPre=/usr/bin/chown mongod:mongod /var/run/mongodb
ExecStartPre=/usr/bin/chmod 0755 /var/run/mongodb
PermissionsStartOnly=true
PIDFile=/var/run/mongodb/mongod.pid
Type=forking
# file size
LimitFSIZE=infinity
# cpu time
LimitCPU=infinity
# virtual memory size
LimitAS=infinity
# open files
LimitNOFILE=64000
# processes/threads
LimitNPROC=64000
# locked memory
LimitMEMLOCK=infinity
# total threads (user+kernel)
TasksMax=infinity
TasksAccounting=false
# Recommended limits for for mongod as specified in
# http://docs.mongodb.org/manual/reference/ulimit/#recommended-settings

[Install]
WantedBy=multi-user.target

mongod.conf 文件,放在 /etc 下

# mongod.conf

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /usr/website/database/mongodb/log/mongod.log

# Where and how to store data.
storage:
  dbPath: /usr/website/database/mongodb/db
  journal:
    enabled: true
#  engine:
#  wiredTiger:

# how the process runs
processManagement:
  fork: true  # fork and run in background
  pidFilePath: /var/run/mongodb/mongod.pid  # location of pidfile
  timeZoneInfo: /usr/share/zoneinfo

# network interfaces
net:
  port: 8114
  bindIp: 0.0.0.0  # Enter 0.0.0.0,:: to bind to all IPv4 and IPv6 addresses or, alternatively, use the net.bindIpAll setting.

#security:
#operationProfiling:
#replication:
#sharding:
## Enterprise-Only Options
#auditLog:
#snmp:

二.安裝.net core的運行時:

	sudo rpm -Uvh https://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項目的文件夾

	mkdir -p /usr/website/api

  然后使用 Bitvise SSH Client 把項目站點文件上傳到文件夾下
  上傳成功后,使用 dotnet xxx.web.dll 試試看項目能不能啟動,如果提示類似下面的,就表示成功了

img

四.創建站點自動啟動的服務

1.創建服務文件

    sudo nano /etc/systemd/system/kestrel-api.service

    內容編輯中,粘貼入:  

	   [Unit]
     Description=Centos RTU Api
 
     [Service]
     WorkingDirectory=/usr/website/api  #工作目錄 
     #調用的,由於非docker,因此端口號都是共用的,所以core 3.x 使用 --urls 設置了端口號,有一個坑就是,在命令行下,--url= 后面可以使用雙引號,,
     #但是在這里不能,加了雙引號就報錯
     ExecStart=/usr/bin/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.注冊服務

    sudo systemctl enable kestrel-api.service
    sudo systemctl start kestrel-api.service
    sudo systemctl status kestrel-api.service

3.命令行下使用 ps -ef

   看到有這條:

img

		就表示運行起來了

  使用

		curl http://localhost:5000
  看看有沒有返回值,並且返回的是不是正確的

  如果無法正確啟動,可以使用微軟站點中介紹的:

		sudo journalctl -fu kestrel-api.service

  在日志中,盡量排查出什么問題,一般的話,如果在第二步中,能正常運行的話,那么大部分情況下,程序上就沒什么問題,主要是一些目錄權限之類的問題
    因為測試的時候是使用root,所以沒什么目錄權限上的問題,

五.處理nginx

1.安裝nginx

  	yum install nginx

2.配置站點

    cd /etc/nginx  #如果是使用sftp的話,一定是要放在 /etc/nginx 目錄下,不能是 /etc 否則要自己去修改nginx對配置文件的查找路徑
    nano nginx.conf

  在 server 段下 再新增一段

	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;
        }
    }

3.nginx的常用命令:

	nginx -s reload   #重新加載配置
	nginx -V          #查看版本
	nginx -t          #測試配置文件是否正確
	nginx -s quit     #關閉服務器端,不過一般推薦從systemctl stop 去關閉

六.開放防火牆端口

      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 的錯誤



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM