网站首页 > 开源技术 正文
如何稳定可靠地运行DeWeb系统,以下我结合www.delphibbs.com的DeWeb部署情况,简要介绍。
一、前期准备
DeWeb目前只能运行在Windows操作系统中,要部署DeWeb应用,需要前期做准备以下:
- Windows操作系统的轻量应用服务器/云服务器,需要的可以 >>>「链接」
- 已备案的域名
- 已申请的ssl证书,用于实现https访问。腾讯云/阿里云都可以免费申请
- nginx。 我用的是小皮
二、基本框架
为了实现稳定可靠的https+DeWeb应用,目前采用的基本框架是:
nginx + DWSGuardor + 10 DeWebServer
其中:
nginx 用于实现较大并发访问和负载平衡,将80端口和443端口转发到8080~8089等10个端口,分别分流到10个DeWebServer中,理论可达2000并发+(按前期测试单个DeWebServer并发200+计算),实际1000+并发应该没问题。
DWSGuardor 用于和多个DeWevServer进行通信,监控DeWebServer的状态,发现异常可以重启指定端口的DeWebServer。
DeWebServer 用于提供指定端口(8080~8089)的DeWeb应用服务,并定时将状态信息发送给DWSGuardor。
三、DeWeb部署
DeWeb部署非常简单,直接把开发机上Source\Runtime目录直接复制到服务器即可以。目录位置随意。 一般建议为D:\DeWeb或C:\DeWeb。参考如下:
四、nginx(小皮)配置
nginx的配置管理工具很多,我用的是小皮,网址小皮面板(phpstudy) - 让天下没有难配的服务器环境!版本是8.1.1.3,其中nginx版本是1.16.1
小皮的套件中包括Apache, FTP, MySQL和nginx, 我只使用了nginx. 大家有更简洁的nginx工具欢迎在评论区留言。感谢!
其中nginx的配置如下
#user nobody;
worker_processes 4;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 40960;
}
http {
include mime.types;
default_type application/octet-stream;
#反向代理配置
upstream server_list{
ip_hash;
server 127.0.0.1:8080;
server 127.0.0.1:8081;
server 127.0.0.1:8082;
server 127.0.0.1:8083;
server 127.0.0.1:8084;
server 127.0.0.1:8085;
server 127.0.0.1:8086;
server 127.0.0.1:8087;
server 127.0.0.1:8088;
server 127.0.0.1:8089;
}
server{
listen 443 ssl;
server_name doc.delphibbs.com;
index ssl.html ;
ssl_certificate c:/ssl/delphibbs.com.crt;
ssl_certificate_key c:/ssl/delphibbs.com.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
ssl_prefer_server_ciphers on;
location / {
proxy_pass http://127.0.0.1:3000;
}
}
server{
listen 80;
server_name doc.delphibbs.com;
location / {
proxy_pass http://127.0.0.1:3000;
}
}
server{
listen 443 ssl;
server_name bbs.delphibbs.com;
index ssl.html ;
ssl_certificate c:/ssl/delphibbs.com.crt;
ssl_certificate_key c:/ssl/delphibbs.com.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
ssl_prefer_server_ciphers on;
location / {
rewrite ^(/.*)$ https://www.delphibbs.com/bbs;
}
}
server{
listen 80;
server_name bbs.delphibbs.com;
location / {
rewrite ^(/.*)$ https://www.delphibbs.com/bbs;
}
}
server{
listen 80;
server_name delphibbs.com www.delphibbs.com;
location / {
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;
#以上三行,目的是将代理服务器收到的用户的信息传到真实服务器上
proxy_pass http://server_list;
# SSE support
proxy_buffering off;
proxy_cache off;
proxy_read_timeout 86400s;
proxy_send_timeout 86400s;
}
location /doc {
proxy_pass http://127.0.0.1:3000/;
}
}
server{
listen 443 ssl;
server_name delphibbs.com www.delphibbs.com;
index ssl.html ;
ssl_certificate c:/ssl/delphibbs.com.crt;
ssl_certificate_key c:/ssl/delphibbs.com.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
ssl_prefer_server_ciphers on;
location / {
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;
#以上三行,目的是将代理服务器收到的用户的信息传到真实服务器上
proxy_pass http://server_list;
# SSE support
proxy_buffering off;
proxy_cache off;
proxy_read_timeout 86400s;
proxy_send_timeout 86400s;
}
location /doc {
proxy_pass http://127.0.0.1:3000/;
}
}
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 443;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
map $time_iso8601 $logdate {
'~^(?<ymd>\\d{4}-\\d{2}-\\d{2})' $ymd;
default 'date-not-found';
}
include vhosts/*.conf;
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
client_max_body_size 50m;
client_body_buffer_size 60k;
client_body_timeout 60;
client_header_buffer_size 64k;
client_header_timeout 60;
error_page 400 /error/400.html;
error_page 403 /error/403.html;
error_page 404 /error/404.html;
error_page 500 /error/500.html;
error_page 501 /error/501.html;
error_page 502 /error/502.html;
error_page 503 /error/503.html;
error_page 504 /error/504.html;
error_page 505 /error/505.html;
error_page 506 /error/506.html;
error_page 507 /error/507.html;
error_page 509 /error/509.html;
error_page 510 /error/510.html;
keepalive_requests 100;
large_client_header_buffers 4 64k;
reset_timedout_connection on;
send_timeout 60;
sendfile_max_chunk 512k;
server_names_hash_bucket_size 256;
}
error_log C:/phpstudy_pro/WWW crit;
worker_rlimit_nofile 100000;
由于我在网站上部署了docsify文档系统,所以这个配置中多了/doc 转到3000端口部分。不需要的可以自行移除
五、https实现
- 申请ssl证书。腾讯云/阿里云都可以免费申请,网上教程很多。不过现在每次只能申请3个月的
- 在腾讯云/阿里云后台网站下载申请的delphibbs.com的证书
- 解压后复制所有文件到指定文件夹(参看nginx配置文件),并重命名为指定文件名
ssl_certificate c:/ssl/delphibbs.com.crt;
ssl_certificate_key c:/ssl/delphibbs.com.key;
- 在小皮中重启nginx
六、DWSGuardor运行管理
DWSGuardor 即 DeWebServer Guardor, 用于对多个DeWebServer进行监控。
一般有一个配置文件:DWSGuardor.ini
[main]
count = 10
port = 8080
left = 500
top = 0
width = 400
height = 90
上述配置表示,
总共启动10个DeWebServer,端口从8080开始,左边距默认为500,上边距为0,宽度为400,高度为90
顶部2个按钮,“启动DWS”按钮用于一次性自动启动多个DeWebServer, “停止”按钮用于一次结束多个DeWebServer。
下部左侧为多个DeWebServer的实时状态,亮色为正常,黑色为故障;
下部右侧为异常重启情况。上图上表示2024年11月7日重启了8086端口对应的DeWebServer。
七、升级维护
DeWeb应用的更新可以通过例程中HotUpdate远程进行;
js/css更新直接修改相应的js/css文件即可,在前端浏览器中需要清除缓存;
dwVcl控件或DeWebServer更新需要先在DWSGuardor中先按“停止”按钮,再更新相应文件
八、实际运行情况
2024年4月由于一些特殊的原因,全封闭无手机无网1个半月,回来发现运行一切正常。
- 上一篇: 我的前端架构养成记之整洁的工作流
- 下一篇: 电脑文件后缀名即扩展名大全
猜你喜欢
- 2024-12-04 VASP中如何固定磁矩大小和方向?
- 2024-12-04 nginx服务的基本配置(nginx.conf文件的详解)
- 2024-12-04 《珈百璃的堕落》声优大空直美作客「铃毛庄」节目!
- 2024-12-04 终极 Nginx 配置指南(全网最详细)
- 2024-12-04 2016上半年度推荐!10个必用的免费Plugins清单!
- 2024-12-04 动漫资讯:只要有邪恶的地方,必定会有英雄出现!
- 2024-12-04 电脑文件后缀名即扩展名大全
- 2024-12-04 我的前端架构养成记之整洁的工作流
- 2024-12-04 PHP面试,从单例模式的两种实现形式讲起
- 2024-08-01 php下载网络图片到本地(php下载网络图片方法)
你 发表评论:
欢迎- 05-16东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 05-16这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 05-16湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- 05-16Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- 05-16G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- 05-16DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 05-16上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- 05-16WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 最近发表
-
- 东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 湖人自媒体调查:89%球迷希望DFS回归 79%希望詹姆斯回归
- 一觉醒来湖人苦盼的纯3D终于到位 DFS能带给紫金军多少帮助
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)