springboot远程执行服务器指令

 更新时间:2023年09月22日 10:58:39   作者:爱刘温柔的小猪  
这篇文章主要介绍了springboot远程执行服务器指令,本例是java远程连接到服务器,去抓取查询kubesphere中的etcd日志,并返回,需要的朋友可以参考下

本例是java远程连接到服务器,去抓取查询kubesphere中的etcd日志,并返回。步骤拆分:

  • 连接到服务器
  • 执行指令获取pod信息:kubectl get po -n kubesphere-system
  • 将pod信息分割,只返回pod名称
  • 根据pod名称,执行指令获取pod日志:kubectl logs -n kubesphere-system "+podName + "
  • –tail=500

1、在工程中引入下方依赖

<dependency>
			<groupId>ch.ethz.ganymed</groupId>
			<artifactId>ganymed-ssh2</artifactId>
			<version>build210</version>
		</dependency>

2、编写连接命令工具类KubeSphereSSHUtils

import ch.ethz.ssh2.Connection;
import ch.ethz.ssh2.Session;
import ch.ethz.ssh2.StreamGobbler;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
@Component
public class KubeSphereSSHUtils {
    private String hostname;
    private String username;
    private String password;
    public void setHostname(String hostname) {
        this.hostname = hostname;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    private static Logger log = LoggerFactory.getLogger(KubeSphereSSHUtils.class);
    public Connection sshConnection() {
        Connection sshConn = null;
        try {
            sshConn = new Connection(hostname);
            sshConn.connect();
            boolean isAuthenticate = sshConn.authenticateWithPassword(username, password);
            if(isAuthenticate == false) {
                throw new IOException("连接到指定环境失败");
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sshConn;
    }
    //获取发布的日志的容器名
    public List<String> getReleasePod(String nameSpaceName, String containName) {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String str = " kubectl get po  -n "+nameSpaceName;
            log.info("执行指令:"+str);
            sess.execCommand(str);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> names = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(StringUtils.isEmpty(line)) {
                    break;
                }
                if(line.startsWith(containName)){
                    names.add(line.split("\\s+")[0]);
                }
            }
            return names;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                conn.close();
                sess.close();
                reader.close();
                inputStreamReader.close();
                is.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    //获取pod内部日志
    public  List<String> getReleaseLogs(String nameSpaceName,String podName, String deploymentName){
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "kubectl logs -n "+nameSpaceName+" "+podName + " --tail=500";
//            String execCommand = "kubectl logs -n "+nameSpaceName+" "+podName + " --tailssss=500";
            log.info("执行指令:"+execCommand);
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    //获取pod内部日志
    public  List<String> getKubeletLogs(){
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "systemctl status kubelet";
            log.info("执行指令:"+execCommand);
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    public List<String> getNodesStatus() {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "kubectl get nodes";
            log.info("执行指令:"+execCommand);
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    public List<String> getNoReadyNodeMessage() {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
//            String execCommand = "kubectl get nodes | grep NotReady | awk '{print$1}'";
            String execCommand = "kubectl get nodes | grep Ready | awk '{print$1}'";
            log.info("执行指令:"+execCommand);
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    public List<String> restartKubelet() {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "systemctl restart kubelet.service";
            log.info("执行指令:"+execCommand);
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    public List<String> getNodeIPMessage() {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "hostname -i";
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
    //重启node机器,慎用!!!!!!
    public List<String> rebootNode() {
        Connection conn = this.sshConnection();
        Session sess = null;
        InputStream is = null;
        InputStreamReader inputStreamReader = null;
        BufferedReader reader = null;
        try {
            sess = conn.openSession();
            String execCommand = "systemctl reboot";
            sess.execCommand(execCommand);
            is = new StreamGobbler(sess.getStdout());
            inputStreamReader = new InputStreamReader(is);
            reader = new BufferedReader(inputStreamReader);
            boolean flg = true;
            List<String> logs = new ArrayList<String>();
            while(flg) {
                String line = reader.readLine();
                if(line == null) {
                    break;
                }
                logs.add(line);
            }
            return logs;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                reader.close();
                inputStreamReader.close();
                is.close();
                conn.close();
                sess.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
}

3、编写配置连接类

@Component
public class DeployUtil {
    private KubeSphereSSHUtils sshUtilsDev;
    private KubeSphereSSHUtils sshUtilsRelease;
    private KubeSphereSSHUtils sshUtilsProd;
    private KubeSphereSSHUtils sshUtilsDev_node1;
    private KubeSphereSSHUtils sshUtilsDev_node2;
    private KubeSphereSSHUtils sshUtilsDev_node3;
    private KubeSphereSSHUtils sshUtilsDev_node4;
    private KubeSphereSSHUtils sshUtilsRelease_node1;
    private KubeSphereSSHUtils sshUtilsRelease_node2;
    private KubeSphereSSHUtils sshUtilsRelease_node3;
    private KubeSphereSSHUtils sshUtilsRelease_node4;
    private KubeSphereSSHUtils sshUtilsRelease_node5;
    private KubeSphereSSHUtils sshUtilsRelease_node6;
    @Autowired
    K8sEnvConfigBean k8sEnvConfigBean;
    @PostConstruct
    public void init() {
        this.createK8sSSHUtils("dev");
        this.createK8sSSHUtils("release");
        this.createK8sSSHUtils("prod");
        this.createK8sSSHNodeUtils_Dev("dev-node1");
        this.createK8sSSHNodeUtils_Dev("dev-node2");
        this.createK8sSSHNodeUtils_Dev("dev-node3");
        this.createK8sSSHNodeUtils_Dev("dev-node4");
        this.createK8sSSHNodeUtils_Release("release-node1");
        this.createK8sSSHNodeUtils_Release("release-node2");
        this.createK8sSSHNodeUtils_Release("release-node3");
        this.createK8sSSHNodeUtils_Release("release-node4");
        this.createK8sSSHNodeUtils_Release("release-node5");
        this.createK8sSSHNodeUtils_Release("release-node6");
    }
    //创建三套环境主节点的连接
    public void createK8sSSHUtils(String env) {
        if(env.equals("dev")) {
            sshUtilsDev = new KubeSphereSSHUtils();
            sshUtilsDev.setPassword(k8sEnvConfigBean.getDevPassword());
            sshUtilsDev.setUsername(k8sEnvConfigBean.getDevUsername());
            sshUtilsDev.setHostname(k8sEnvConfigBean.getDevHost());
        }else if(env.equals("release")) {
            sshUtilsRelease = new KubeSphereSSHUtils();
            sshUtilsRelease.setPassword(k8sEnvConfigBean.getReleasePassword());
            sshUtilsRelease.setUsername(k8sEnvConfigBean.getReleaseUsername());
            sshUtilsRelease.setHostname(k8sEnvConfigBean.getReleaseHost());
        }else if(env.equals("prod")) {
            sshUtilsProd = new KubeSphereSSHUtils();
            sshUtilsProd.setPassword(k8sEnvConfigBean.getProdPassword());
            sshUtilsProd.setUsername(k8sEnvConfigBean.getProdUsername());
            sshUtilsProd.setHostname(k8sEnvConfigBean.getProdHost());
        }
    }
    //创建dev环境子节点的连接
    public void createK8sSSHNodeUtils_Dev(String env) {
        switch (env) {
            case "dev-node1":
                sshUtilsDev_node1 = new KubeSphereSSHUtils();
                sshUtilsDev_node1.setPassword(k8sEnvConfigBean.getDev_node1_password());
                sshUtilsDev_node1.setUsername(k8sEnvConfigBean.getDev_node1_username());
                sshUtilsDev_node1.setHostname(k8sEnvConfigBean.getDev_node1_host());
                break;
            case "dev-node2":
                sshUtilsDev_node2 = new KubeSphereSSHUtils();
                sshUtilsDev_node2.setPassword(k8sEnvConfigBean.getDev_node2_password());
                sshUtilsDev_node2.setUsername(k8sEnvConfigBean.getDev_node2_username());
                sshUtilsDev_node2.setHostname(k8sEnvConfigBean.getDev_node2_host());
                break;
            case "dev-node3":
                sshUtilsDev_node3 = new KubeSphereSSHUtils();
                sshUtilsDev_node3.setPassword(k8sEnvConfigBean.getDev_node3_password());
                sshUtilsDev_node3.setUsername(k8sEnvConfigBean.getDev_node3_username());
                sshUtilsDev_node3.setHostname(k8sEnvConfigBean.getDev_node3_host());
                break;
            case "dev-node4":
                sshUtilsDev_node4 = new KubeSphereSSHUtils();
                sshUtilsDev_node4.setPassword(k8sEnvConfigBean.getDev_node4_password());
                sshUtilsDev_node4.setUsername(k8sEnvConfigBean.getDev_node4_username());
                sshUtilsDev_node4.setHostname(k8sEnvConfigBean.getDev_node4_host());
        }
    }
    //创建release环境子节点连接
    public void createK8sSSHNodeUtils_Release(String env) {
        switch (env) {
            case "release-node1":
                sshUtilsRelease_node1 = new KubeSphereSSHUtils();
                sshUtilsRelease_node1.setPassword(k8sEnvConfigBean.getRelease_node1_password());
                sshUtilsRelease_node1.setUsername(k8sEnvConfigBean.getRelease_node1_username());
                sshUtilsRelease_node1.setHostname(k8sEnvConfigBean.getRelease_node1_host());
                break;
            case "release-node2":
                sshUtilsRelease_node2 = new KubeSphereSSHUtils();
                sshUtilsRelease_node2.setPassword(k8sEnvConfigBean.getRelease_node2_password());
                sshUtilsRelease_node2.setUsername(k8sEnvConfigBean.getRelease_node2_username());
                sshUtilsRelease_node2.setHostname(k8sEnvConfigBean.getRelease_node2_host());
                break;
            case "release-node3":
                sshUtilsRelease_node3 = new KubeSphereSSHUtils();
                sshUtilsRelease_node3.setPassword(k8sEnvConfigBean.getRelease_node3_password());
                sshUtilsRelease_node3.setUsername(k8sEnvConfigBean.getRelease_node3_username());
                sshUtilsRelease_node3.setHostname(k8sEnvConfigBean.getRelease_node3_host());
                break;
            case "release-node4":
                sshUtilsRelease_node4 = new KubeSphereSSHUtils();
                sshUtilsRelease_node4.setPassword(k8sEnvConfigBean.getRelease_node4_password());
                sshUtilsRelease_node4.setUsername(k8sEnvConfigBean.getRelease_node4_username());
                sshUtilsRelease_node4.setHostname(k8sEnvConfigBean.getRelease_node4_host());
                break;
            case "release-node5":
                sshUtilsRelease_node5 = new KubeSphereSSHUtils();
                sshUtilsRelease_node5.setPassword(k8sEnvConfigBean.getRelease_node5_password());
                sshUtilsRelease_node5.setUsername(k8sEnvConfigBean.getRelease_node5_username());
                sshUtilsRelease_node5.setHostname(k8sEnvConfigBean.getRelease_node5_host());
            case "release-node6":
                sshUtilsRelease_node6 = new KubeSphereSSHUtils();
                sshUtilsRelease_node6.setPassword(k8sEnvConfigBean.getRelease_node6_password());
                sshUtilsRelease_node6.setUsername(k8sEnvConfigBean.getRelease_node6_username());
                sshUtilsRelease_node6.setHostname(k8sEnvConfigBean.getRelease_node6_host());
        }
    }
    //获取相应环境的某台机器的连接
    public KubeSphereSSHUtils getK8sSSHUtils(String env) {
        KubeSphereSSHUtils result = null;
        if(env.equals("dev")) {
            if (this.sshUtilsDev == null) {
                this.createK8sSSHUtils(env);
            }
            result = sshUtilsDev;
        }else if(env.equals("release")) {
            if (this.sshUtilsRelease == null) {
                this.createK8sSSHUtils(env);
            }
            result = sshUtilsRelease;
        }else if(env.equals("prod")) {
            if (this.sshUtilsProd == null) {
                this.createK8sSSHUtils(env);
            }
            result = sshUtilsProd;
        }
        //新增操作dev节点的逻辑
        else if(env.equals("dev-node1")) {
            if (this.sshUtilsDev_node1 == null) {
                this.createK8sSSHNodeUtils_Dev(env);
            }
            result = sshUtilsDev_node1;
        }else if(env.equals("dev-node2")) {
            if (this.sshUtilsDev_node2 == null) {
                this.createK8sSSHNodeUtils_Dev(env);
            }
            result = sshUtilsDev_node2;
        }else if(env.equals("dev-node3")) {
            if (this.sshUtilsDev_node3 == null) {
                this.createK8sSSHNodeUtils_Dev(env);
            }
            result = sshUtilsDev_node3;
        }else if(env.equals("dev-node4")) {
            if (this.sshUtilsDev_node4 == null) {
                this.createK8sSSHNodeUtils_Dev(env);
            }
            result = sshUtilsDev_node4;
        }
        //新增操作release节点的逻辑
        else if(env.equals("release-node1")) {
            if (this.sshUtilsRelease_node1 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node1;
        }else if(env.equals("release-node2")) {
            if (this.sshUtilsRelease_node2 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node2;
        }else if(env.equals("release-node3")) {
            if (this.sshUtilsRelease_node3 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node3;
        }else if(env.equals("release-node4")) {
            if (this.sshUtilsRelease_node4 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node4;
        }else if(env.equals("release-node5")) {
            if (this.sshUtilsRelease_node5 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node5;
        }else if(env.equals("release-node6")) {
            if (this.sshUtilsRelease_node6 == null) {
                this.createK8sSSHNodeUtils_Release(env);
            }
            result = sshUtilsRelease_node6;
        }
        return result;
    }
    //寻找环境下的某一个子节点物理机,便于重启该机器
    public String getNodeEnvType(String nodeName,String env) {
        String k8sEnv = null;
        if(Objects.equals(env,"dev")){ //dev环境机器匹配,不匹配主节点
            switch (nodeName) {
                case "node1":
                    k8sEnv = "dev-node1";
                    break;
                case "node2":
                    k8sEnv = "dev-node2";
                    break;
                case "node3":
                    k8sEnv = "dev-node3";
                    break;
                case "node4":
                    k8sEnv = "dev-node4";
                    break;
            }
        } else if(Objects.equals(env,"release")) { //release环境机器匹配,不匹配主节点
            switch (nodeName) {
                case "node1":
                    k8sEnv = "release-node1";
                    break;
                case "node2":
                    k8sEnv = "release-node2";
                    break;
                case "node3":
                    k8sEnv = "release-node3";
                    break;
                case "node4":
                    k8sEnv = "release-node4";
                    break;
                case "node5":
                    k8sEnv = "release-node5";
                    break;
                case "node6":
                    k8sEnv = "release-node6";
                    break;
            }
        }
        //prod环境机器暂时不开启自动重启功能
        return k8sEnv;
    }
}

4、调用时的代码如下:

KubeSphereSSHUtils sshUtils = deployUtils.getK8sSSHUtils(env);//连接到指令环境
List<String> podNames = sshUtils.getReleasePod(KUBESPHERE_NAMESPACE, KUBESPHERE_ETCD_CONTAINNAME); //获取pod名称
List<String> logs = sshUtils.getReleaseLogs(KUBESPHERE_NAMESPACE, podName, KUBESPHERE_ETCD_CONTAINNAME);//获取日志

到此这篇关于springboot远程执行服务器指令的文章就介绍到这了,更多相关springboot服务器指令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring Boot2.0整合ES5实现文章内容搜索实战

    Spring Boot2.0整合ES5实现文章内容搜索实战

    这篇文章主要介绍了Spring Boot2.0整合ES5实现文章内容搜索实战,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • IntelliJ-Idea导出可执行Jar流程解析

    IntelliJ-Idea导出可执行Jar流程解析

    这篇文章主要介绍了IntelliJ-Idea导出可执行Jar流程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12
  • java 中二分法查找的应用实例

    java 中二分法查找的应用实例

    这篇文章主要介绍了java 中二分法查找的应用实例的相关资料,希望通过本文大家能掌握二分法的使用方法,需要的朋友可以参考下
    2017-09-09
  • spring boot打包成可执行jar包

    spring boot打包成可执行jar包

    本篇文章主要介绍了spring boot打包成可执行jar包,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • SpringMVC post请求中文乱码问题解决

    SpringMVC post请求中文乱码问题解决

    这篇文章主要介绍了SpringMVC post请求中文乱码问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Java HttpClient实现socks代理的示例代码

    Java HttpClient实现socks代理的示例代码

    这篇文章主要介绍了Java HttpClient 实现 socks 代理的示例代码,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-11-11
  • 对dbunit进行mybatis DAO层Excel单元测试(必看篇)

    对dbunit进行mybatis DAO层Excel单元测试(必看篇)

    下面小编就为大家带来一篇对dbunit进行mybatis DAO层Excel单元测试(必看篇)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Java中的static关键字修饰属性和方法(推荐)

    Java中的static关键字修饰属性和方法(推荐)

    这篇文章主要介绍了Java中的static关键字修饰属性和方法,包括哪些成员属性可以被static修饰,静态属性的访问方法示例详解,需要的朋友可以参考下
    2022-04-04
  • Spring Cloud Gateway 获取请求体(Request Body)的多种方法

    Spring Cloud Gateway 获取请求体(Request Body)的多种方法

    这篇文章主要介绍了Spring Cloud Gateway 获取请求体(Request Body)的多种方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 向Spring IOC 容器动态注册bean实现方式

    向Spring IOC 容器动态注册bean实现方式

    这篇文章主要为大家介绍了向Spring IOC 容器动态注册bean实现方式详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论