Heim >Betrieb und Instandhaltung >Nginx >Lassen Sie uns darüber sprechen, wie Sie Nginx zum Bereitstellen des TienChin-Projekts verwenden
In diesem Artikel lernen Freunde Schritt für Schritt, wie sie das TienChin-Projekt implementieren. Lassen Sie uns dieses Projekt gemeinsam durchführen, um zu sehen, um welche Art von Projekt es sich handelt.
Freunde wissen, dass wir bei dieser Art von Projekt mit Front-End- und Back-End-Trennung, wenn wir es tatsächlich bereitstellen, es so bereitstellen können, dass Front-End und Back-End getrennt sind, oder wir kann es so bereitstellen, dass Front-End und Back-End nicht getrennt sind. Als Nächstes werde ich meinen Freunden zwei verschiedene Bereitstellungsmethoden vorstellen.
Wenn Front-End und Back-End separat bereitgestellt werden, benötigen wir normalerweise zuerst einen Nginx-Server Ein einfaches Bereitstellungsdiagramm als Referenz:
Eine einfache Erklärung lautet:
Okay, das ist unser grobes Diagramm der Bereitstellungsarchitektur, es ist sehr einfach.
Es gibt mehrere Dinge, die wir im Voraus vorbereiten müssen.
Lassen Sie uns zunächst MySQL und Redis auf dem Server installieren. Ich werde nicht näher auf die Installation eingehen, es ist nur ein grundlegender Vorgang.
MySQL empfiehlt die Verwendung von Docker zur Installation, um Ärger zu vermeiden. Wenn Sie Docker nicht verstehen, können Sie im Hintergrund des offiziellen Kontos auf Docker antworten. Außerdem gibt es ein von Brother Song geschriebenes Einführungs-Tutorial. Brother Song hat ein Redis-Tutorial direkt in der vorherigen vhr-Tutorialreihe installiert Sie können im Hintergrund des offiziellen Kontos auf vhr antworten, um die Details anzuzeigen.
Damit sind unsere Vorbereitungen abgeschlossen.
Zuerst müssen wir unser Projekt von GitHub abrufen. Sie können es direkt klonen:
Führen Sie Git Clone einfach direkt aus.
Nach dem Herunterziehen gibt es zwei Ordner:
Zuerst erstellen wir eine Datenbank mit dem Namen Tienchin, was leicht zu sagen ist.
Als nächstes suchen wir die Datei tienchin/sql/tienchin-video_2023-03-13.sql
und führen das Skript in der Tienchin-Datenbank aus. tienchin/sql/tienchin-video_2023-03-13.sql
文件,在 tienchin 数据库中执行该脚本。
接下来,我们找到 tienchin/tienchin-admin/src/main/resources/application-druid.yml
文件,在该文件中,根据自己的实际情况,修改数据库连接地址、数据库名称、用户名和密码。
继续打开 tienchin/tienchin-admin/src/main/resources/application.yml
文件,在该文件中配置 Redis 的地址、密码等信息。
另外还有一个非常重要的配置也需要修改,就是在 tienchin/tienchin-admin/src/main/resources/application.yml
文件中,将 server.servlet.context-path
的值改为 /prod-api
。
接下来我们进行服务端打包。小伙伴们需要在自己电脑上安装好 Maven 并且配置好环境变量,这也是基本操作,我就不啰嗦了。
如果电脑上还没有配置 Maven 的话,建议使用 IDEA 自带的 Maven 插件,就不用额外下载了。IDEA 自带的 Maven 插件在安装目录下的
Als nächstes finden wir die Dateiplugins/maven
tienchin/tienchin-admin/src/main/resources/application-druid.yml
. Ändern Sie in dieser Datei die Datenbankverbindungsadresse und die Datenbank entsprechend Ihrer tatsächlichen Situation. Name, Benutzername und Passwort.
Öffnen Sie weiterhin die Datei tienchin/tienchin-admin/src/main/resources/application.yml
und konfigurieren Sie die Redis-Adresse, das Passwort und andere Informationen in der Datei.
Es gibt auch eine sehr wichtige Konfiguration, die ebenfalls geändert werden muss, nämlich server.servlet.context im <code>tienchin/tienchin-admin/src/main/resources/application.yml zu ändern. code>-Datei Der Wert von -path
wird in /prod-api
geändert.
1.3.3 Serverseitige Verpackung
🎜Als nächstes führen wir die serverseitige Verpackung durch. Freunde, Sie müssen Maven auf Ihrem Computer installieren und die Umgebungsvariablen konfigurieren. Dies ist ebenfalls ein grundlegender Vorgang, daher werde ich nicht auf Details eingehen. 🎜🎜🎜Wenn Maven auf Ihrem Computer nicht konfiguriert ist, wird empfohlen, das mit IDEA gelieferte Maven-Plug-in zu verwenden, sodass Sie es nicht zusätzlich herunterladen müssen. Das mit IDEA gelieferte Maven-Plug-in befindet sich im Verzeichnisplugins/maven
im Installationsverzeichnis. Sie können das bin-Verzeichnis hier direkt für die Umgebungsvariable konfigurieren. 🎜🎜🎜Für die serverseitige Verpackung geben wir das Tienchin-Verzeichnis ein und führen dann den folgenden Code aus: 🎜mvn package -Dmaven.test.skip=true🎜Das Sehen des folgenden Codes bedeutet, dass die Kompilierung erfolgreich ist: 🎜🎜🎜🎜
编译成功之后,在 tienchin/tienchin-admin/target
目录下,可以看到一个名为 tienchin-admin.jar
的 jar 文件,这就是我们所需要的服务端代码。
接下来进入到 tienchin-ui
目录下,执行如下命令安装依赖(注意,前端需要 NodeJS 至少 14 往上的版本):
npm install
然后再执行如下命令进行编译打包:
npm run build:prod
打包完成后,会生成 dist 目录,里边的文件就是我们所需要的静态资源文件:
这样,前端代码就打包完成了。
接下来我们来安装 Nginx,我这里直接下载 Nginx 源码进行编译安装,步骤如下:
yum install -y zlib-devel yum -y install pcre pcre-devel
wget https://nginx.org/download/nginx-1.22.1.tar.gztar -zxvf nginx-1.22.1.tar.gz
进入到 nginx 解压目录中,分别执行如下命令进行编译安装:
./configuremakemake install
如此之后,我们的 Nginx 就安装好了。
接下来我们首先通过命令或者文件上传工具,先把刚刚打包的后端的 tienchin-admin.jar 和前端的 dist 目录上传到服务器上面来。
接下来,我们首先启动服务端这个 tienchin-admin.jar
:
nohup java -jar tienchin-admin.jar > tienchin.log &
有的小伙伴在服务端部署的时候,会抛出如下异常:
这个是因为服务端缺乏相应的字体,而 Flowable 在自动生成部署图片的时候,需要用到这些字体,所以我们安装需要的字体即可:
yum install fontconfig fc-cache --force
服务端启动成功之后,我们先用 postman 测试一下登录接口,确保能运行,就说明服务端部署成功:
能成功登录,就说明服务端部署成功。
接下来部署前端。
前端部署很简单,我们只需要将 dist 中的内容拷贝到 nginx 的 html 目录下即可,命令如下:
cp dist/* /usr/local/nginx/html/
接下来执行如下命令启动 nginx:
/usr/local/nginx/sbin/nginx
nginx 启动成功之后,就可以浏览器中访问页面了:
当然,现在还登录不了,因为还缺少 Nginx 的请求转发,现在当我们请求 Nginx 的时候可以看到前端页面,但是服务端的数据请求,Nginx 并不会自动转发到 Spring Boot 上面去,所以还需要我们继续配置 Nginx,Nginx 配置文件的位置在 /usr/local/nginx/conf/nginx.conf
,我们增加如下配置:
location /prod-api { proxy_pass http://127.0.0.1:8080; tcp_nodelay on; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { root /usr/local/nginx/html/; expires 30d; try_files $uri $uri/ /index.html; }
这里有几个配置参数的含义,我给大家稍微解释下:
配置完成后,重启 Nginx:
/usr/local/nginx/sbin/nginx -s reload
好啦,这次重启之后,就可以顺利玩耍啦~
前后端不分部署相对就简单一些,不需要 Nginx 了,不过前面 1.3.1-1.3.4
也是需要的。
1.3.4 小节中,我们拿到前端编译打包后的内容后,直接放到 tienchin-admin 模块的 static 静态资源目录下,然后继续将服务端打成 jar 包,将 jar 包上传到服务器并启动即可,启动命令和 1.3.6 小节介绍的 jar 包启动命令一致,这个过程比较简单,涉及到的相关命令前面都有介绍,我就不重复展示了。
最后,对 TienChin 项目感兴趣的小伙伴戳这里:TienChin 项目配套视频来啦。
Empfohlenes Tutorial: Nginx-Tutorial
Das obige ist der detaillierte Inhalt vonLassen Sie uns darüber sprechen, wie Sie Nginx zum Bereitstellen des TienChin-Projekts verwenden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!