Selaa lähdekoodia

日志文件查看

gaoxiong 1 vuosi sitten
vanhempi
commit
ab0fba75c5

+ 2 - 1
pom.xml

@@ -19,6 +19,7 @@
         <spring-cloud.version>2021.0.5</spring-cloud.version>
         <spring-cloud-alibaba.version>2021.0.4.0</spring-cloud-alibaba.version>
         <spring-boot-admin.version>2.7.10</spring-boot-admin.version>
+
         <swagger.fox.version>3.0.0</swagger.fox.version>
         <swagger.core.version>1.6.2</swagger.core.version>
         <druid.version>1.2.16</druid.version>
@@ -39,7 +40,7 @@
         <commons.lang3.version>3.12.0</commons.lang3.version>
         <okhttp.version>3.10.0</okhttp.version>
         <lombok.version>1.18.26</lombok.version>
-        <generator.version>3.4.1</generator.version>
+        <generator.version>3.5.1</generator.version>
         <freemarker.version>2.7.2</freemarker.version>
         <velocity.version>2.3</velocity.version>
         <knife4j.version>3.0.3</knife4j.version>

+ 101 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/controller/SysServerController.java

@@ -0,0 +1,101 @@
+package com.xunmei.system.controller;
+
+import java.util.List;
+import java.io.IOException;
+import javax.servlet.http.HttpServletResponse;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.PutMapping;
+import org.springframework.web.bind.annotation.DeleteMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+import com.xunmei.common.log.annotation.Log;
+import com.xunmei.common.log.enums.BusinessType;
+import com.xunmei.common.security.annotation.RequiresPermissions;
+import com.xunmei.system.domain.SysServer;
+import com.xunmei.system.service.ISysServerService;
+import com.xunmei.common.core.web.controller.BaseController;
+import com.xunmei.common.core.web.domain.AjaxResult;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xunmei.common.core.web.page.TableDataInfo;
+
+/**
+ * 服务器维护Controller
+ *
+ * @author xunmei
+ * @date 2024-09-29
+ */
+@Api(tags = {"SysServer"})
+@RestController
+@RequestMapping("/server")
+public class SysServerController extends BaseController {
+    @Autowired
+    private ISysServerService sysServerService;
+
+    /**
+     * 查询服务器维护列表
+     */
+    @ApiOperation(value = "查询SysServer列表")
+    @RequiresPermissions("system:server:list")
+    @GetMapping("/list")
+    public TableDataInfo<SysServer> list(SysServer sysServer) {
+
+        return sysServerService.selectPage(sysServer);
+    }
+
+    /**
+     * 获取服务器维护详细信息
+     */
+    @ApiOperation(value = "获取SysServer详细信息")
+    @RequiresPermissions("system:server:query")
+    @GetMapping(value = "/{id}")
+    public AjaxResult getInfo(@PathVariable("id") Long id) {
+        return success(sysServerService.selectSysServerById(id));
+    }
+
+    /**
+     * 新增服务器维护
+     */
+    @ApiOperation(value = "新增SysServer")
+    @RequiresPermissions("system:server:add")
+    @Log(title = "服务器维护", businessType = BusinessType.INSERT)
+    @PostMapping
+    public AjaxResult add(@RequestBody SysServer sysServer) {
+        return toAjax(sysServerService.insertSysServer(sysServer));
+    }
+
+    /**
+     * 修改服务器维护
+     */
+    @ApiOperation(value = "修改SysServer")
+    @RequiresPermissions("system:server:edit")
+    @Log(title = "服务器维护", businessType = BusinessType.UPDATE)
+    @PutMapping
+    public AjaxResult edit(@RequestBody SysServer sysServer) {
+        return toAjax(sysServerService.updateSysServer(sysServer));
+    }
+
+    /**
+     * 删除服务器维护
+     */
+    @ApiOperation(value = "删除SysServer")
+    @RequiresPermissions("system:server:remove")
+    @Log(title = "服务器维护", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public AjaxResult remove(@PathVariable Long[] ids) {
+        return toAjax(sysServerService.deleteSysServerByIds(ids));
+    }
+
+    @ApiOperation(value = "查询SysServer列表")
+    @PostMapping("/logs")
+    public AjaxResult getLogs(@RequestBody SysServer sysServer) {
+        Object logs = sysServerService.getLogs(sysServer);
+        return success(logs);
+    }
+}

+ 72 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/domain/SysServer.java

@@ -0,0 +1,72 @@
+package com.xunmei.system.domain;
+
+import org.apache.commons.lang3.builder.ToStringBuilder;
+import org.apache.commons.lang3.builder.ToStringStyle;
+
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.baomidou.mybatisplus.annotation.IdType;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+import com.xunmei.common.core.web.domain.BaseEntity;
+
+/**
+ * 服务器维护对象 sys_server
+ *
+ * @author xunmei
+ * @date 2024-09-29
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+@Accessors(chain = true)
+@TableName("sys_server")
+@ApiModel(value = "SysServer对象", description = "服务器维护")
+public class SysServer extends BaseEntity {
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    private Long id;
+
+    /**
+     * 服务器ip
+     */
+    @ApiModelProperty(value = "服务器ip")
+    private String serverIp;
+
+    /**
+     * 看门猫token
+     */
+    private String serverToken;
+
+    /**
+     * 看门猫端口
+     */
+    @ApiModelProperty(value = "看门猫端口")
+    private String serverPort;
+
+    /**
+     * 服务器名称
+     */
+    @ApiModelProperty(value = "服务器名称")
+    private String serverName;
+
+
+    @Override
+    public String toString() {
+        return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE)
+                .append("id", getId())
+                .append("serverIp", getServerIp())
+                .append("serverToken", getServerToken())
+                .append("serverPort", getServerPort())
+                .append("serverName", getServerName())
+                .append("createBy", getCreateBy())
+                .append("createTime", getCreateTime())
+                .append("updateBy", getUpdateBy())
+                .append("updateTime", getUpdateTime())
+                .toString();
+    }
+}

+ 64 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/mapper/SysServerMapper.java

@@ -0,0 +1,64 @@
+package com.xunmei.system.mapper;
+
+import java.util.List;
+
+import com.xunmei.system.domain.SysServer;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * 服务器维护Mapper接口
+ *
+ * @author xunmei
+ * @date 2024-09-29
+ */
+@Mapper
+public interface SysServerMapper extends BaseMapper<SysServer> {
+    /**
+     * 查询服务器维护
+     *
+     * @param id 服务器维护主键
+     * @return 服务器维护
+     */
+    SysServer selectSysServerById(Long id);
+
+    /**
+     * 查询服务器维护列表
+     *
+     * @param sysServer 服务器维护
+     * @return 服务器维护集合
+     */
+    List<SysServer> selectSysServerList(SysServer sysServer);
+
+    /**
+     * 新增服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    int insertSysServer(SysServer sysServer);
+
+    /**
+     * 修改服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    int updateSysServer(SysServer sysServer);
+
+    /**
+     * 删除服务器维护
+     *
+     * @param id 服务器维护主键
+     * @return 结果
+     */
+    int deleteSysServerById(Long id);
+
+    /**
+     * 批量删除服务器维护
+     *
+     * @param ids 需要删除的数据主键集合
+     * @return 结果
+     */
+    int deleteSysServerByIds(Long[] ids);
+}

+ 79 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/service/ISysServerService.java

@@ -0,0 +1,79 @@
+package com.xunmei.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.xunmei.common.core.web.page.TableDataInfo;
+import com.xunmei.system.domain.SysServer;
+import org.springframework.web.bind.annotation.RequestBody;
+
+import java.util.List;
+
+/**
+ * 服务器维护Service接口
+ *
+ * @author xunmei
+ * @date 2024-09-29
+ */
+public interface ISysServerService extends IService<SysServer> {
+    /**
+     * 查询服务器维护
+     *
+     * @param id 服务器维护主键
+     * @return 服务器维护
+     */
+    SysServer selectSysServerById(Long id);
+
+    /**
+     * 查询服务器维护列表
+     *
+     * @param sysServer 服务器维护
+     * @return 服务器维护集合
+     */
+    List<SysServer> selectSysServerList(SysServer sysServer);
+
+    /**
+     * 新增服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    int insertSysServer(SysServer sysServer);
+
+    /**
+     * 修改服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    int updateSysServer(SysServer sysServer);
+
+    /**
+     * 批量删除服务器维护
+     *
+     * @param ids 需要删除的服务器维护主键集合
+     * @return 结果
+     */
+    int deleteSysServerByIds(Long[] ids);
+
+    /**
+     * 删除服务器维护信息
+     *
+     * @param id 服务器维护主键
+     * @return 结果
+     */
+    int deleteSysServerById(Long id);
+
+    /**
+     * 查询服务器维护分页数据
+     *
+     * @param sysServer 查询条件对象
+     * @return Page
+     */
+    TableDataInfo<SysServer> selectPage(SysServer sysServer);
+
+    /**
+     * 获取此服务器下的日志文件
+     * @param sysServer
+     * @return
+     */
+    Object getLogs( SysServer sysServer);
+}

+ 153 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/service/impl/SysServerServiceImpl.java

@@ -0,0 +1,153 @@
+package com.xunmei.system.service.impl;
+
+import java.util.List;
+
+import cn.hutool.http.HttpResponse;
+import cn.hutool.http.HttpUtil;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson2.JSONArray;
+import com.alibaba.fastjson2.JSONObject;
+import com.alibaba.fastjson2.JSONReader;
+import com.xunmei.common.core.utils.DateUtils;
+import com.xunmei.system.vo.server.CheckListVo;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.Arrays;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xunmei.common.core.web.page.TableDataInfo;
+import com.xunmei.system.mapper.SysServerMapper;
+import com.xunmei.system.domain.SysServer;
+import com.xunmei.system.service.ISysServerService;
+
+/**
+ * 服务器维护Service业务层处理
+ *
+ * @author xunmei
+ * @date 2024-09-29
+ */
+@Service
+public class SysServerServiceImpl extends ServiceImpl<SysServerMapper, SysServer> implements ISysServerService {
+
+    @Autowired
+    private SysServerMapper sysServerMapper;
+
+    @Override
+    public TableDataInfo<SysServer> selectPage(SysServer sysServer) {
+        //未删除
+        Page<SysServer> page;
+        //分页
+        if (sysServer.getPageNum() != null && sysServer.getPageSize() != null) {
+            page = new Page<>(sysServer.getPageNum(), sysServer.getPageSize());
+        } else {
+            page = new Page<>();
+        }
+        //查询条件
+        QueryWrapper<SysServer> query = new QueryWrapper<>(sysServer);
+        //获取数据
+        page = sysServerMapper.selectPage(page, query);
+        //抓换为TableDataInfo适配前端
+        return TableDataInfo.build(page);
+
+
+    }
+
+    @Override
+    public Object getLogs(SysServer sysServer) {
+        SysServer server = this.selectSysServerById(sysServer.getId());
+        StringBuffer baseUrl = new StringBuffer("http://");
+        baseUrl.append(server.getServerIp()).append(":")
+                        .append(server.getServerPort());
+        String rootUrl = baseUrl.toString();
+
+        String getServices = "/result/list?size=10000&current=1";
+        String getLogs = "/result/fileList?checkId=";
+
+        //获取服务器列表
+        HttpResponse response = HttpUtil.createPost(rootUrl + getServices)
+                .header("Token", server.getServerToken())
+                .execute();
+        String serverJson = response.body();
+        JSONObject parse = JSONObject.parse(serverJson);
+        List<CheckListVo> checks = JSONArray.parseArray(parse.getString("rows"), CheckListVo.class);
+
+        for (CheckListVo check : checks) {
+            System.out.println(JSON.toJSONString(check));
+
+        }
+
+        return null;
+    }
+
+
+    /**
+     * 查询服务器维护
+     *
+     * @param id 服务器维护主键
+     * @return 服务器维护
+     */
+    @Override
+    public SysServer selectSysServerById(Long id) {
+        return sysServerMapper.selectById(id);
+    }
+
+    /**
+     * 查询服务器维护列表
+     *
+     * @param sysServer 服务器维护
+     * @return 服务器维护
+     */
+    @Override
+    public List<SysServer> selectSysServerList(SysServer sysServer) {
+        return sysServerMapper.selectList(new QueryWrapper<>(sysServer));
+    }
+
+    /**
+     * 新增服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    @Override
+    public int insertSysServer(SysServer sysServer) {
+        sysServer.setCreateTime(DateUtils.getNowDate());
+        return sysServerMapper.insert(sysServer);
+    }
+
+    /**
+     * 修改服务器维护
+     *
+     * @param sysServer 服务器维护
+     * @return 结果
+     */
+    @Override
+    public int updateSysServer(SysServer sysServer) {
+        sysServer.setUpdateTime(DateUtils.getNowDate());
+        return sysServerMapper.updateById(sysServer);
+    }
+
+    /**
+     * 批量删除服务器维护
+     *
+     * @param ids 需要删除的服务器维护主键
+     * @return 结果
+     */
+    @Override
+    public int deleteSysServerByIds(Long[] ids) {
+        return sysServerMapper.deleteBatchIds(Arrays.asList((ids)));
+    }
+
+    /**
+     * 删除服务器维护信息
+     *
+     * @param id 服务器维护主键
+     * @return 结果
+     */
+    @Override
+    public int deleteSysServerById(Long id) {
+        return sysServerMapper.deleteById(id);
+    }
+}

+ 56 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/vo/server/CheckListVo.java

@@ -0,0 +1,56 @@
+package com.xunmei.system.vo.server;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.io.Serializable;
+import java.util.Date;
+
+@Data
+@AllArgsConstructor
+@NoArgsConstructor
+public class CheckListVo  implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 服务名称
+     */
+    private String checkName;
+    /**
+     * 服务中文名称
+     */
+    private String displayName;
+
+    /**
+     * 进程名称
+     */
+    private String pId;
+
+    /**
+     * 服务版本号
+     */
+    private String checkVersion;
+
+    /**
+     * 服务启动时间
+     */
+    private Date checkStartTime;
+
+    /**
+     * 服务状态 0:未启动,1:重启中,2:已启动
+     */
+    private Integer checkStatus;
+
+    /**
+     * 日志文件路径
+     */
+    private String logDir;
+
+    /**
+     * 启动时长
+     */
+    private String startLong;
+
+}

+ 53 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/vo/server/FileInfoVo.java

@@ -0,0 +1,53 @@
+package com.xunmei.system.vo.server;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.io.Serializable;
+
+@Data
+@AllArgsConstructor
+@NoArgsConstructor
+public class FileInfoVo implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+    /**
+     * 文件名称
+     */
+    private String fileName;
+    /**
+     * 文件大小
+     */
+    private String fileSize;
+    /**
+     * 文件类型
+     */
+    private int fileType;
+    /**
+     * 当前路径
+     */
+    private String path;
+    /**
+     * 父级路径
+     */
+    private String parentPath;
+    /**
+     * 图标
+     */
+    private String icon;
+    /**
+     * id
+     */
+    private String id;
+    /**
+     * 父级id
+     */
+    private String parentId;
+
+    /**
+     * 父级id
+     */
+    private String createTime = "";
+}
+

+ 32 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/vo/server/ServerInfoVo.java

@@ -0,0 +1,32 @@
+package com.xunmei.system.vo.server;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.io.Serializable;
+
+/**
+ * 服务名称
+ */
+@Data
+@AllArgsConstructor
+@NoArgsConstructor
+public class ServerInfoVo implements Serializable {
+
+    private Long id;
+    /**
+     * 服务器IP
+     */
+    private String serverIp;
+    /**
+     * 服务器名称
+     */
+    private String serverName;
+
+
+
+
+
+
+}

+ 129 - 0
soc-modules/soc-modules-system/src/main/resources/mapper/system/SysServerMapper.xml

@@ -0,0 +1,129 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.xunmei.system.mapper.SysServerMapper">
+
+    <resultMap type="com.xunmei.system.domain.SysServer" id="SysServerResult">
+                <result property="id" column="id"/>
+                <result property="serverIp" column="server_ip"/>
+                <result property="serverToken" column="server_token"/>
+                <result property="serverPort" column="server_port"/>
+                <result property="serverName" column="server_name"/>
+                <result property="createBy" column="create_by"/>
+                <result property="createTime" column="create_time"/>
+                <result property="updateBy" column="update_by"/>
+                <result property="updateTime" column="update_time"/>
+    </resultMap>
+
+    <sql id="selectSysServerVo">
+        select id, server_ip, server_token, server_port, server_name, create_by, create_time, update_by, update_time
+        from sys_server
+    </sql>
+
+    <select id="selectSysServerList" parameterType="com.xunmei.system.domain.SysServer"
+            resultMap="SysServerResult">
+        <include refid="selectSysServerVo"/>
+        <where>
+                        <if test="serverIp != null  and serverIp != ''">
+                            and server_ip = #{serverIp}
+                        </if>
+                        <if test="serverName != null  and serverName != ''">
+                            and server_name like concat('%', #{serverName}, '%')
+                        </if>
+        </where>
+    </select>
+
+    <select id="selectSysServerById" parameterType="Long"
+            resultMap="SysServerResult">
+            <include refid="selectSysServerVo"/>
+            where id = #{id}
+    </select>
+
+    <insert id="insertSysServer" parameterType="com.xunmei.system.domain.SysServer">
+        insert into sys_server
+        <trim prefix="(" suffix=")" suffixOverrides=",">
+                    <if test="id != null">id,
+                    </if>
+                    <if test="serverIp != null and serverIp != ''">server_ip,
+                    </if>
+                    <if test="serverToken != null">server_token,
+                    </if>
+                    <if test="serverPort != null">server_port,
+                    </if>
+                    <if test="serverName != null">server_name,
+                    </if>
+                    <if test="createBy != null">create_by,
+                    </if>
+                    <if test="createTime != null">create_time,
+                    </if>
+                    <if test="updateBy != null">update_by,
+                    </if>
+                    <if test="updateTime != null">update_time,
+                    </if>
+        </trim>
+        <trim prefix="values (" suffix=")" suffixOverrides=",">
+                    <if test="id != null">#{id},
+                    </if>
+                    <if test="serverIp != null and serverIp != ''">#{serverIp},
+                    </if>
+                    <if test="serverToken != null">#{serverToken},
+                    </if>
+                    <if test="serverPort != null">#{serverPort},
+                    </if>
+                    <if test="serverName != null">#{serverName},
+                    </if>
+                    <if test="createBy != null">#{createBy},
+                    </if>
+                    <if test="createTime != null">#{createTime},
+                    </if>
+                    <if test="updateBy != null">#{updateBy},
+                    </if>
+                    <if test="updateTime != null">#{updateTime},
+                    </if>
+        </trim>
+    </insert>
+
+    <update id="updateSysServer" parameterType="com.xunmei.system.domain.SysServer">
+        update sys_server
+        <trim prefix="SET" suffixOverrides=",">
+                    <if test="serverIp != null and serverIp != ''">server_ip =
+                        #{serverIp},
+                    </if>
+                    <if test="serverToken != null">server_token =
+                        #{serverToken},
+                    </if>
+                    <if test="serverPort != null">server_port =
+                        #{serverPort},
+                    </if>
+                    <if test="serverName != null">server_name =
+                        #{serverName},
+                    </if>
+                    <if test="createBy != null">create_by =
+                        #{createBy},
+                    </if>
+                    <if test="createTime != null">create_time =
+                        #{createTime},
+                    </if>
+                    <if test="updateBy != null">update_by =
+                        #{updateBy},
+                    </if>
+                    <if test="updateTime != null">update_time =
+                        #{updateTime},
+                    </if>
+        </trim>
+        where id = #{id}
+    </update>
+
+    <delete id="deleteSysServerById" parameterType="Long">
+        delete
+        from sys_server where id = #{id}
+    </delete>
+
+    <delete id="deleteSysServerByIds" parameterType="String">
+        delete from sys_server where id in
+        <foreach item="id" collection="array" open="(" separator="," close=")">
+            #{id}
+        </foreach>
+    </delete>
+</mapper>