最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

Windows Server版部署java服务

业界 admin 15浏览 0评论

Windows Server 2022部署java web服务

由于服务器中了勒索病毒,不得不清空硬盘,所有东西都要重新部署,为此写下博客,记录部署过程,为以后的自己提供参考。


目录

  • Windows Server 2022部署java web服务
  • 一、各种软件安装
    • 1.JDK
    • 2.MySql
    • 3.Nginx
    • 4.Redis
  • 二、数据恢复、运行jar、Nginx配置、端口映射
    • 1.数据恢复
    • 2.运行jar
    • 3.Nginx配置
    • 4.端口映射
  • 三、脚本
    • 1.Jar
      • 1)启动Jar
      • 2)线程守护
      • 3)关闭Jar
    • 2.Nginx
    • 3.Redis
  • 四、开机自启动
  • 五、MySql的自动备份脚本


一、各种软件安装

阿里云 本来是都分享了的,但是压缩包阿里云暂不支持分享,不知后续是否支持。

1.JDK

JDK安装教程
建议安装jdk-8u202这个,之前安装的jdk-8u111,在对接微信支付的时候,出BUG,升级了JDK就好了,当时时间紧迫,也没来得及深究,有知道的小伙伴可以留言告知。

2.MySql

先用解压包解压,然后添加my.ini配置文件的方式运行MySql服务,但是一切配置好了,运行提示我少文件,让我重新下载,没办法,就下载的安装包
本次有参考 MySQL下载教程
自定义MySQL安装
下载VC_redist.x64.exe

3.Nginx

下载安装包,解压即可用
记得去nginx.conf文件中不Nginx的端口从80改为其他端口,我修改的是888

4.Redis

下载安装包,解压即可用

由于项目是jar包的方式,所以没有安装TomCat


二、数据恢复、运行jar、Nginx配置、端口映射

1.数据恢复

过程中,有张表报错了 Got a packet bigger than ‘max_allowed_packet’ bytes
查看帖子解决了

#查看数据库中最大的单个文件容量

SHOW VARIABLES LIKE ‘%max_allowed_packet%‘; 

#设置最大单个文件容量为20M,单次有效

SET GLOBAL max_allowed_packet=20*1024*1024 

2.运行jar

java -jar -Xms256m -Xmx512m .\xxx.jar >  .\log.log &

3.Nginx配置

由于要配置HTTPS协议请求,所以要先去阿里云SSL 证书管理页面,把证书下载下来

配置过程中,还遇到配置多个ssl server,每次请求下面的地址时,都会进入第一个server的页面,百度说输入nginx -V 查看是否有 TLS SNI support enabled 有就支持,没有就需要安装模块。但是我的显示支持,还是出现了这个问题,一顿瞎操作,后来才发现,我自己应该不小心点到了nginx.exe,启动了多个服务,在任务管理其中关闭所有Nginx服务,重新启动就解决了

由于有个项目要传非常大的文件上来,所以真的这个server,添加了一下单独配置

client_max_body_size        800G; # 文件最大大小
keepalive_timeout 1800s;          # 指定 KeepAlive 的超时时间(timeout)。指定每个 TCP 连接最多可以保持多长时间。Nginx 的默认值是 75 秒,有些浏览器最多只保持 60 秒,所以可以设定为 60 秒。若将它设置为 0,就禁止了 keepalive 连接。
proxy_connect_timeout 1800s;      # nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 1800s;         # 后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 1800s;         # 连接成功后,后端服务器响应时间(代理接收超时)
fastcgi_connect_timeout 1800s;    # 指定nginx与后端fastcgi server连接超时时间
fastcgi_send_timeout 1800s;       # 指定nginx向后端传送请求超时时间(指已完成两次握手后向fastcgi传送请求超时时间)
fastcgi_read_timeout 1800s;       # 指定nginx向后端传送响应超时时间(指已完成两次握手后向fastcgi传送响应超时时间)

Windows Server和Windows还有的细微的区别,就是root地址中的斜杠只能是'/','\'会识别不到目录

4.端口映射

这个服务器网络是通过光猫连接路由器,然后再通过路由器某端口连到服务器上的,所以服务器是内网IP,光猫是外网固定IP。想访问服务器,就要去路由器设置里面做映射才行(首先要把服务器设置为固定IP,防止重启后IP变了,映射失效的问题),由于每款路由器设置可能不同,这里就不作记录了


三、脚本

1.Jar

1)启动Jar

为了不让jar运行一直有个DOS窗口,就编写了个脚本,让它后台静默运行

@echo off

if "%1"=="h" goto begin 

start mshta vbscript:createobject("wscript.shell").run("""%~nx0"" h",0)(window.close)&&exit 

:begin 

set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%"

java -jar -Xms256m -Xmx512m .\xxx.jar >>  .\log_%Ymd%.log &

@echo on

2)线程守护

为了防止项目停止,需要连接服务器,手动启动的麻烦,编写了个脚本一直监控

@echo off

set jarName=jarName.jar
@echo %jarName% daemon thread start
 
:START_CHECK
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%"
jps -l | findstr /i  "%jarName%" || goto STARTPRO
ping -n 10 127.0.0.1 > nul
goto START_CHECK
 
 
:STARTPRO
@echo %Ymd%   start %jarName% process...
:: start后面的就是上面那个启动jar脚本的名称
start 1.bat
:: -n后面的数字是多少  就是sleep多少秒
ping -n 20 127.0.0.1 > nul
goto START_CHECK

@echo on

3)关闭Jar

为了停止服务不要每次都去 netstat -aon|findstr "8080" taskkill /f /pid 端口 而编写了个脚本

@echo off
set port=8080
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do (
    echo kill the process %%m who use the port 
    taskkill /pid %%m -t -f
    goto q
)
:q

2.Nginx

@echo off
if "%1" == "h" goto begin 
  mshta vbscript:createobject("wscript.shell").run("%~nx0 h",0)(window.close)&&exit 
begin 

:: cd后面是Nginx的安装目录
cd ...\nginx-1.9.10

start nginx

exit

停止:nginx.exe -s quit
重载:nginx.exe -s reload
重新打开日志:nginx.exe -s reopen

3.Redis

@echo off
 
if "%1" == "h" goto begin 
  mshta vbscript:createobject("wscript.shell").run("%~nx0 h",0)(window.close)&&exit 
:begin

:: cd后面是Redis的安装目录
cd ...\Redis

redis-server redis.windows.conf

以上的路径,最好都写绝对路径,这样移动了文件也能试用

四、开机自启动

以上启动脚本创建快捷打开方式,放到 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp 目录下面,开机后就会自动运行了

五、MySql的自动备份脚本

要先在E:\mysql_backup下面建好对应数据库名的文件夹

rem ******MySQL backup start******
    @echo off

    set "user=root"
    set "password=123456"

    ::规定数组长度
    set objLength=7

    ::给数组设值
    set obj[0] =数据库名
    set obj[1] =数据库名
    set obj[2] =数据库名
    set obj[3] =数据库名
    set obj[4] =数据库名
    set obj[5] =数据库名
    set obj[6] =数据库名
    ::set obj[7] =数据库名

    ::初始索引
    set objIndex=0
    
    ::设置时间变量
    set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%"
    
    ::进入mysql安装目录的bin目录下
    D:
    cd D:/java/mysql8.0.28/bin/

    ::循环
    :loopStart

    ::判断索引值是否大于数组长度,大于的话跳到结束,不大于的话继续循环
    if %objIndex% equ %objLength% goto end

    ::初始化变量
    set objCurrent=0

    ::这个循环是数组对象处理循环,就是处理单个对象。/f是参数格式 usebackq声明路径有空格
    for /f "usebackq delims== tokens=1-2" %%i in (`set obj[%objIndex%]`) do (

          ::赋值变量
          set objCurrent=%%j
          echo %%j

    ::删除一周前的备份数据
    forfiles /p "E:\mysql_backup\%%j" /m backup_*.sql -d -7 /c "cmd /c del /f @path"

    ::执行备份操作
    mysqldump --opt --single-transaction=TRUE --user=%user% --password=%password% --host=127.0.0.1 --protocol=tcp --port=3306 --default-character-set=utf8 --single-transaction=TRUE --routines --events "%%j" --hex-blob > E:\mysql_backup\%%j\backup_%Ymd%.sql
     )

    ::索引+1
    set /a objIndex=%objIndex% + 1

    ::继续循环
    goto loopStart

    :end

    @echo on
rem ******MySQL backup end******

然后添加Windows定时任务,这样就可以每天备份数据库了

如果用上面的脚本,备份时间最好设置在每天10:00:00之后,因为十点之前 set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%" 有问题,会导致备份失败

Windows Server 2022部署java web服务

由于服务器中了勒索病毒,不得不清空硬盘,所有东西都要重新部署,为此写下博客,记录部署过程,为以后的自己提供参考。


目录

  • Windows Server 2022部署java web服务
  • 一、各种软件安装
    • 1.JDK
    • 2.MySql
    • 3.Nginx
    • 4.Redis
  • 二、数据恢复、运行jar、Nginx配置、端口映射
    • 1.数据恢复
    • 2.运行jar
    • 3.Nginx配置
    • 4.端口映射
  • 三、脚本
    • 1.Jar
      • 1)启动Jar
      • 2)线程守护
      • 3)关闭Jar
    • 2.Nginx
    • 3.Redis
  • 四、开机自启动
  • 五、MySql的自动备份脚本


一、各种软件安装

阿里云 本来是都分享了的,但是压缩包阿里云暂不支持分享,不知后续是否支持。

1.JDK

JDK安装教程
建议安装jdk-8u202这个,之前安装的jdk-8u111,在对接微信支付的时候,出BUG,升级了JDK就好了,当时时间紧迫,也没来得及深究,有知道的小伙伴可以留言告知。

2.MySql

先用解压包解压,然后添加my.ini配置文件的方式运行MySql服务,但是一切配置好了,运行提示我少文件,让我重新下载,没办法,就下载的安装包
本次有参考 MySQL下载教程
自定义MySQL安装
下载VC_redist.x64.exe

3.Nginx

下载安装包,解压即可用
记得去nginx.conf文件中不Nginx的端口从80改为其他端口,我修改的是888

4.Redis

下载安装包,解压即可用

由于项目是jar包的方式,所以没有安装TomCat


二、数据恢复、运行jar、Nginx配置、端口映射

1.数据恢复

过程中,有张表报错了 Got a packet bigger than ‘max_allowed_packet’ bytes
查看帖子解决了

#查看数据库中最大的单个文件容量

SHOW VARIABLES LIKE ‘%max_allowed_packet%‘; 

#设置最大单个文件容量为20M,单次有效

SET GLOBAL max_allowed_packet=20*1024*1024 

2.运行jar

java -jar -Xms256m -Xmx512m .\xxx.jar >  .\log.log &

3.Nginx配置

由于要配置HTTPS协议请求,所以要先去阿里云SSL 证书管理页面,把证书下载下来

配置过程中,还遇到配置多个ssl server,每次请求下面的地址时,都会进入第一个server的页面,百度说输入nginx -V 查看是否有 TLS SNI support enabled 有就支持,没有就需要安装模块。但是我的显示支持,还是出现了这个问题,一顿瞎操作,后来才发现,我自己应该不小心点到了nginx.exe,启动了多个服务,在任务管理其中关闭所有Nginx服务,重新启动就解决了

由于有个项目要传非常大的文件上来,所以真的这个server,添加了一下单独配置

client_max_body_size        800G; # 文件最大大小
keepalive_timeout 1800s;          # 指定 KeepAlive 的超时时间(timeout)。指定每个 TCP 连接最多可以保持多长时间。Nginx 的默认值是 75 秒,有些浏览器最多只保持 60 秒,所以可以设定为 60 秒。若将它设置为 0,就禁止了 keepalive 连接。
proxy_connect_timeout 1800s;      # nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 1800s;         # 后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 1800s;         # 连接成功后,后端服务器响应时间(代理接收超时)
fastcgi_connect_timeout 1800s;    # 指定nginx与后端fastcgi server连接超时时间
fastcgi_send_timeout 1800s;       # 指定nginx向后端传送请求超时时间(指已完成两次握手后向fastcgi传送请求超时时间)
fastcgi_read_timeout 1800s;       # 指定nginx向后端传送响应超时时间(指已完成两次握手后向fastcgi传送响应超时时间)

Windows Server和Windows还有的细微的区别,就是root地址中的斜杠只能是'/','\'会识别不到目录

4.端口映射

这个服务器网络是通过光猫连接路由器,然后再通过路由器某端口连到服务器上的,所以服务器是内网IP,光猫是外网固定IP。想访问服务器,就要去路由器设置里面做映射才行(首先要把服务器设置为固定IP,防止重启后IP变了,映射失效的问题),由于每款路由器设置可能不同,这里就不作记录了


三、脚本

1.Jar

1)启动Jar

为了不让jar运行一直有个DOS窗口,就编写了个脚本,让它后台静默运行

@echo off

if "%1"=="h" goto begin 

start mshta vbscript:createobject("wscript.shell").run("""%~nx0"" h",0)(window.close)&&exit 

:begin 

set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%"

java -jar -Xms256m -Xmx512m .\xxx.jar >>  .\log_%Ymd%.log &

@echo on

2)线程守护

为了防止项目停止,需要连接服务器,手动启动的麻烦,编写了个脚本一直监控

@echo off

set jarName=jarName.jar
@echo %jarName% daemon thread start
 
:START_CHECK
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%"
jps -l | findstr /i  "%jarName%" || goto STARTPRO
ping -n 10 127.0.0.1 > nul
goto START_CHECK
 
 
:STARTPRO
@echo %Ymd%   start %jarName% process...
:: start后面的就是上面那个启动jar脚本的名称
start 1.bat
:: -n后面的数字是多少  就是sleep多少秒
ping -n 20 127.0.0.1 > nul
goto START_CHECK

@echo on

3)关闭Jar

为了停止服务不要每次都去 netstat -aon|findstr "8080" taskkill /f /pid 端口 而编写了个脚本

@echo off
set port=8080
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do (
    echo kill the process %%m who use the port 
    taskkill /pid %%m -t -f
    goto q
)
:q

2.Nginx

@echo off
if "%1" == "h" goto begin 
  mshta vbscript:createobject("wscript.shell").run("%~nx0 h",0)(window.close)&&exit 
begin 

:: cd后面是Nginx的安装目录
cd ...\nginx-1.9.10

start nginx

exit

停止:nginx.exe -s quit
重载:nginx.exe -s reload
重新打开日志:nginx.exe -s reopen

3.Redis

@echo off
 
if "%1" == "h" goto begin 
  mshta vbscript:createobject("wscript.shell").run("%~nx0 h",0)(window.close)&&exit 
:begin

:: cd后面是Redis的安装目录
cd ...\Redis

redis-server redis.windows.conf

以上的路径,最好都写绝对路径,这样移动了文件也能试用

四、开机自启动

以上启动脚本创建快捷打开方式,放到 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp 目录下面,开机后就会自动运行了

五、MySql的自动备份脚本

要先在E:\mysql_backup下面建好对应数据库名的文件夹

rem ******MySQL backup start******
    @echo off

    set "user=root"
    set "password=123456"

    ::规定数组长度
    set objLength=7

    ::给数组设值
    set obj[0] =数据库名
    set obj[1] =数据库名
    set obj[2] =数据库名
    set obj[3] =数据库名
    set obj[4] =数据库名
    set obj[5] =数据库名
    set obj[6] =数据库名
    ::set obj[7] =数据库名

    ::初始索引
    set objIndex=0
    
    ::设置时间变量
    set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%"
    
    ::进入mysql安装目录的bin目录下
    D:
    cd D:/java/mysql8.0.28/bin/

    ::循环
    :loopStart

    ::判断索引值是否大于数组长度,大于的话跳到结束,不大于的话继续循环
    if %objIndex% equ %objLength% goto end

    ::初始化变量
    set objCurrent=0

    ::这个循环是数组对象处理循环,就是处理单个对象。/f是参数格式 usebackq声明路径有空格
    for /f "usebackq delims== tokens=1-2" %%i in (`set obj[%objIndex%]`) do (

          ::赋值变量
          set objCurrent=%%j
          echo %%j

    ::删除一周前的备份数据
    forfiles /p "E:\mysql_backup\%%j" /m backup_*.sql -d -7 /c "cmd /c del /f @path"

    ::执行备份操作
    mysqldump --opt --single-transaction=TRUE --user=%user% --password=%password% --host=127.0.0.1 --protocol=tcp --port=3306 --default-character-set=utf8 --single-transaction=TRUE --routines --events "%%j" --hex-blob > E:\mysql_backup\%%j\backup_%Ymd%.sql
     )

    ::索引+1
    set /a objIndex=%objIndex% + 1

    ::继续循环
    goto loopStart

    :end

    @echo on
rem ******MySQL backup end******

然后添加Windows定时任务,这样就可以每天备份数据库了

如果用上面的脚本,备份时间最好设置在每天10:00:00之后,因为十点之前 set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%" 有问题,会导致备份失败

发布评论

评论列表 (0)

  1. 暂无评论