openfire 4.7.5 Web插件开发

news2025/1/10 17:33:16

文章目录

    • 1、openfire服务端下载安装
      • 1.1、openfire解压运行
      • 1.2、Spark安装和登录
    • 2、openfire插件开发
      • 2.1、基于servlet开发http接口
      • 2.2、基于Jersey开发http接口
      • 2.3、WEB UI页面开发
      • 2.4、上传插件
        • 2.4.1、访问servlet接口效果
        • 2.4.2、访问Jersey接口效果
        • 2.4.3、访问页面效果

Openfire 采用Java开发,开源的实时协作(RTC)服务器基于XMPP(Jabber)协议。如果要搭建企业内部IM服务、内部系统集成、或对消息数据有安全要求(数据必须保存在内部),Openfire还是一个最好的选择之一,而且开源免费、二次扩展也方便。
Spark是Openfire的pc客户端应用。
本文仅介绍Openfire的基本安装与扩展开发

1、openfire服务端下载安装

官网下载地址:https://igniterealtime.org/downloads/

1.1、openfire解压运行

openfire_4_7_5.zip:https://igniterealtime.org/downloadServlet?filename=openfire/openfire_4_7_5.zip
openfire_4_7_5.zip解压
在这里插入图片描述

window下运行openfire服务器端,在命令行下输入以下命令:

bin\openfire.bat

在这里插入图片描述

浏览器访问:http://localhost:9090/,然后按界面提示配置数据库、管理员帐号密码等安装步骤。
在这里插入图片描述

1.2、Spark安装和登录

本文使用版本spark_3_0_2-64bit.exe:https://igniterealtime.org/downloadServlet?filename=spark/spark_3_0_2-64bit.exe
双击安装即可
安装后的启动界面:
在这里插入图片描述

默认情况下,是登录失败,报certificate_unkown错误,需要在高级设置里面做设置,选择下边两行:
在这里插入图片描述

登录前需要先在Openfire服务器端创建帐号:
在这里插入图片描述

2、openfire插件开发

本文分别介绍基于servlet和Jersey开发http插件,插件的开发可以参考官方的例子:https://igniterealtime.org/projects/openfire/plugins.jsp
完成后的插件代码目录如下:
在这里插入图片描述

  • pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <artifactId>plugins</artifactId>
        <groupId>org.igniterealtime.openfire</groupId>
        <version>4.7.0</version>
    </parent>
    <groupId>org.igniterealtime.openfire.plugins</groupId>
    <artifactId>dbcdc</artifactId>
    <version>1.0.0</version>
    <name>dbcdc Plugin</name>
    <description>Openfire plugin to CDC database</description>
    <properties>
        <jersey.version>2.36</jersey.version>
    </properties>
    <build>
        <sourceDirectory>src/java</sourceDirectory>
        <plugins>
            <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>org.eclipse.jetty</groupId>
                <artifactId>jetty-jspc-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>org.glassfish.jersey.containers</groupId>
            <artifactId>jersey-container-jetty-http</artifactId>
            <version>${jersey.version}</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.containers</groupId>
            <artifactId>jersey-container-jetty-servlet</artifactId>
            <version>${jersey.version}</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.inject</groupId>
            <artifactId>jersey-hk2</artifactId>
            <version>${jersey.version}</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.media</groupId>
            <artifactId>jersey-media-jaxb</artifactId>
            <version>${jersey.version}</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.media</groupId>
            <artifactId>jersey-media-json-jackson</artifactId>
            <version>${jersey.version}</version>
        </dependency>
    </dependencies>

    <repositories>
        <repository>
            <id>igniterealtime</id>
            <name>Ignite Realtime Repository</name>
            <url>https://igniterealtime.org/archiva/repository/maven/</url>
        </repository>
    </repositories>

    <pluginRepositories>
        <pluginRepository>
            <id>igniterealtime</id>
            <name>Ignite Realtime Repository</name>
            <url>https://igniterealtime.org/archiva/repository/maven/</url>
        </pluginRepository>
    </pluginRepositories>

</project>
  • 所有插件都要实现org.jivesoftware.openfire.container.Plugin接口的java类,DbCdcPlugin.java
package org.igniterealtime.openfire.exampleplugin;

import org.jivesoftware.openfire.PresenceManager;
import org.jivesoftware.openfire.SessionManager;
import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.container.Plugin;
import org.jivesoftware.openfire.container.PluginManager;
import org.jivesoftware.openfire.group.Group;
import org.jivesoftware.openfire.group.GroupManager;
import org.jivesoftware.openfire.interceptor.InterceptorManager;
import org.jivesoftware.openfire.interceptor.PacketInterceptor;
import org.jivesoftware.openfire.interceptor.PacketRejectedException;
import org.jivesoftware.openfire.muc.MultiUserChatService;
import org.jivesoftware.openfire.roster.RosterManager;
import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.openfire.spi.PresenceManagerImpl;
import org.jivesoftware.openfire.user.UserManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xmpp.packet.Message;
import org.xmpp.packet.Packet;

import java.io.File;
import java.util.Collection;
import java.util.List;

public class DbCdcPlugin implements Plugin, PacketInterceptor {
    private static final Logger log = LoggerFactory.getLogger(DbCdcPlugin.class);

    public final UserManager userManager;
    public final RosterManager rosterManager;
    public final GroupManager groupManager;
    public final XMPPServer server;
    public final SessionManager sessionManager;
    public final PresenceManager presenceManager;
    private InterceptorManager interceptorManager;

    public DbCdcPlugin(){

        server = XMPPServer.getInstance();
        userManager = server.getUserManager();
        // 所有花名册管理。
        rosterManager = server.getRosterManager();
        groupManager = GroupManager.getInstance();
        // 用户组
        groupManager.getGroups().forEach(group->{
            log.info("DbPlugin group===========" + group.getName());
        });


        server.getMultiUserChatManager().getMultiUserChatServices().forEach(muchat->{
            log.info("DbPlugin muchat===========" + muchat.getServiceName() + "," + muchat.getDescription() + "," + muchat.getServiceDomain());
        });
        // 所有会话管理
        sessionManager = server.getSessionManager();
        // 在线状态管理
        presenceManager = server.getPresenceManager();

        interceptorManager = InterceptorManager.getInstance();
        interceptorManager.addInterceptor(this);
    }

    public void initializePlugin(PluginManager pluginManager, File file) {
        log.info("DbCdcPlugin================" );
    }

    public void destroyPlugin() {
        interceptorManager.removeInterceptor(this);
        log.info("DbCdcPlugin  destroyPlugin================" );
    }

    public void sendServerMessage(String msg){
        SessionManager.getInstance().sendServerMessage(null, msg);
    }

    public Collection<Group> getGroups(){
        return groupManager.getGroups();
    }

    public List<MultiUserChatService> getRooms(){
        return server.getMultiUserChatManager().getMultiUserChatServices();
    }

    @Override
    public void interceptPacket(Packet packet, Session session, boolean incoming, boolean processed) throws PacketRejectedException {
        if(packet instanceof Message){
            Message message = (Message)packet;
            if(message.getType().equals(Message.Type.chat)){
                // 打印日志
                log.info("groupchat========incoming:" + incoming + ",processed:" + processed + "," + message.toXML());
            }
        }
    }
}

plugin.xml配置插件启动类

<?xml version="1.0" encoding="UTF-8"?>

<plugin>
    <class>org.igniterealtime.openfire.exampleplugin.DbCdcPlugin</class>
    <name>Db CDC</name>
    <description>An Db CDC plugin that does nothing interesting</description>
    <author>penngo</author>
    <version>1.0.15</version>
    <date>09/24/2023</date>
    <minServerVersion>4.7.0</minServerVersion>
    <adminconsole>
        <tab id="tab-server">
            <sidebar id="sidebar-server-settings">
                <item id="dbcdc-plugin-page" name="Db CDC" url="dbcdcplugin-page.jsp" description="Db CDC Plugin" />
            </sidebar>
        </tab>
    </adminconsole>
</plugin>

2.1、基于servlet开发http接口

接口访问地址:http://localhost:9090/plugins/dbcdc/user?user=test1
DataServlet.java

package org.igniterealtime.openfire.service;

import com.fasterxml.jackson.databind.ObjectMapper;
import org.igniterealtime.openfire.exampleplugin.DbCdcPlugin;
import org.jivesoftware.admin.AuthCheckFilter;
import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.user.User;
import org.jivesoftware.openfire.user.UserNotFoundException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.*;

public class UserServlet extends HttpServlet {
    private static final Logger log = LoggerFactory.getLogger(UserServlet.class);
    private DbCdcPlugin plugin;

    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
        super.init(servletConfig);
        plugin = (DbCdcPlugin) XMPPServer.getInstance().getPluginManager().getPlugin( "dbcdc" );
        AuthCheckFilter.addExclude("dbcdc/user");
    }

    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        handle(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        handle(request, response);
    }
    
    private void handle(HttpServletRequest request,
                        HttpServletResponse response) throws ServletException, IOException {
        Map<String, String[]> parame = request.getParameterMap();

        String name = request.getParameter("user");

        Collection<User> users = plugin.userManager.getUsers();
        Map<String, Object> data = new HashMap<>();
        List<Object> list = new ArrayList<>();
        for(User user:users){
            Map obj = new HashMap();
            obj.put("name", user.getName());
            obj.put("username", user.getUsername());
            list.add(obj);
        }
        Map obj = new HashMap();
        try{
            User user = plugin.userManager.getUser(name);
            obj.put("name", user.getName());
            obj.put("username", user.getUsername());
        }
        catch (UserNotFoundException e) {
            //throw new RuntimeException(e);
            log.error("UserNotFoundException=====" + name, e);
        }

        data.put("search", obj);
        data.put("users", list);
        replyMessage(toJson(data), response);
    }

    private void replyMessage(String message, HttpServletResponse response) throws IOException{
        PrintWriter out = response.getWriter();
        response.setContentType("text/json");
        out.println(message);
        out.flush();
    }

    public String toJson(Object obj){
        String json = null;
        try{
            ObjectMapper mapper=new ObjectMapper();
            json = mapper.writeValueAsString(obj);
        }
        catch(Exception e){

        }
        return json;
    }

    @Override
    public void destroy() {
        super.destroy();
        AuthCheckFilter.removeExclude("dbcdc/user");
    }
}

web-custom.xml则是对servlet等动态注册的配置页面,类似Tomcat中的web.xml配置

<?xml version='1.0' encoding='ISO-8859-1'?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
    <!-- Servlets -->
    <servlet>
        <servlet-name>UserServlet</servlet-name>
        <servlet-class>org.igniterealtime.openfire.service.UserServlet</servlet-class>
    </servlet>

    <!-- Servlet mappings -->
    <servlet-mapping>
        <servlet-name>UserServlet</servlet-name>
        <url-pattern>/user</url-pattern>
    </servlet-mapping>

</web-app>

2.2、基于Jersey开发http接口

Jersey是一个用于构建RESTful Web服务的开源框架。它基于Java语言和JAX-RS(Java API for RESTful Web Services)标准,并提供了简洁的API和丰富的功能。
JerseyWrapper.java


public class JerseyWrapper extends ResourceConfig {
    private static final org.slf4j.Logger log = LoggerFactory.getLogger(JerseyWrapper.class);

    private static String loadingStatusMessage = null;

    public JerseyWrapper(@Context ServletConfig servletConfig) {
        log.info("JerseyWrapper========");
        registerClasses(
            UserService.class
        );
    }
}

接口实现类

package org.igniterealtime.openfire.service;

import org.igniterealtime.openfire.exampleplugin.DbCdcPlugin;
import org.jivesoftware.admin.AuthCheckFilter;
import org.jivesoftware.openfire.MessageRouter;
import org.jivesoftware.openfire.SessionManager;
import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.group.Group;
import org.jivesoftware.openfire.muc.MUCRoom;
import org.jivesoftware.openfire.muc.MultiUserChatService;
import org.jivesoftware.openfire.user.User;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xmpp.packet.JID;
import org.xmpp.packet.Message;

import javax.annotation.PostConstruct;
import javax.ws.rs.*;
import javax.ws.rs.core.MediaType;
import java.util.*;


@Path("dbcdc/v1/user")
public class UserService {
    private static final Logger log = LoggerFactory.getLogger(UserService.class);
    private DbCdcPlugin plugin;
    @PostConstruct
    public void init() {
        plugin = (DbCdcPlugin) XMPPServer.getInstance().getPluginManager().getPlugin( "dbcdc" );
        // 允许非登录也能访问http接口
        AuthCheckFilter.addExclude("dbcdc/v1/user/getUsers");
    }

    // 访问地址:http://localhost:9090/plugins/dbcdc/v1/user/getUsers?name=test1
    @GET
    @Path("/getUsers")
    @Produces(MediaType.APPLICATION_JSON)
    public Map<String, Object> getUsers(@QueryParam("user") String name) throws Exception{
        Boolean isEsist = false;
        Collection<User> users = plugin.userManager.getUsers();
        Map<String, Object> data = new HashMap<>();
        List<Object> list = new ArrayList<>();
        for(User user:users){
            Map obj = new HashMap();
            obj.put("name", user.getName());
            obj.put("username", user.getUsername());
            list.add(obj);
        }
        User user = plugin.userManager.getUser(name);
        Map obj = new HashMap();
        obj.put("name", user.getName());
        obj.put("username", user.getUsername());

        data.put("search", obj);
        data.put("users", list);
        return data;
    }
}

2.3、WEB UI页面开发

openfire的页面是支持jsp技术开发的。
dbcdcplugin-page.jsp页面代码

<%@ page
   import="org.jivesoftware.openfire.XMPPServer,
           org.igniterealtime.openfire.exampleplugin.DbCdcPlugin,
           org.jivesoftware.util.CookieUtils,
           org.jivesoftware.util.ParamUtils,
           org.jivesoftware.util.StringUtils,
           java.util.HashMap"
	errorPage="error.jsp"%>
<%@ page import="java.util.Map" %>

<%@ taglib uri="admin" prefix="admin" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>

<%
    final boolean save = request.getParameter( "save" ) != null;

    final Cookie csrfCookie = CookieUtils.getCookie( request, "csrf" );
    final String csrfParam = ParamUtils.getParameter( request, "csrf" );
    final String exampleText = ParamUtils.getParameter( request, "exampletext" );

    final DbCdcPlugin plugin = (DbCdcPlugin) XMPPServer.getInstance().getPluginManager().getPlugin( "dbcdcplugin" );

    final Map<String, String> errors = new HashMap<>();
    if ( save )
    {
        // CSRF has to be done manually.
        if ( csrfCookie == null || csrfParam == null || !csrfCookie.getValue().equals( csrfParam ) )
        {
            errors.put( "csrf", "CSRF Failure!" );
        }

        if ( exampleText == null || exampleText.isEmpty() )
        {
            errors.put( "exampleText", "" );
        }

        if ( errors.isEmpty() )
        {
            response.sendRedirect( "dbcdc-page.jsp?settingsSaved=true" );
            return;
        }
    }

    final String csrf = StringUtils.randomString( 15 );
    CookieUtils.setCookie( request, response, "csrf", csrf, -1 );

    pageContext.setAttribute( "csrf", csrf );
    pageContext.setAttribute( "errors", errors );
    pageContext.setAttribute( "exampleText", exampleText );
%>

<html>
	<head>
	  <title><fmt:message key="dbcdcplugin.title" /></title>
	  <meta name="pageID" content="dbcdc-plugin-page"/>
	</head>
	<body>

	<c:choose>
		<c:when test="${not empty param.settingsSaved and empty errors}">
			<admin:infoBox type="success"><fmt:message key="dbcdcplugin.saved.success" /></admin:infoBox>
		</c:when>
		<c:otherwise>
			<c:forEach var="err" items="${errors}">
				<admin:infobox type="error">
					<c:choose>
						<c:when test="${err.key eq 'exampleText'}"><fmt:message key="dbcdcplugin.text.missing"/></c:when>
						<c:otherwise>
							<c:if test="${not empty err.value}">
								<c:out value="${err.value}"/>
							</c:if>
							(<c:out value="${err.key}"/>)
						</c:otherwise>
					</c:choose>
				</admin:infobox>
			</c:forEach>
		</c:otherwise>
	</c:choose>

	<p><fmt:message key="dbcdcplugin.directions" /></p>

	<form action="dbcdc-page.jsp?save" method="post">

        <fmt:message key="dbcdcplugin.options" var="boxtitle"/>
		<admin:contentBox title="${boxtitle}">

			<table cellpadding="3" cellspacing="0" border="0" width="100%">
				<tr>
					<td width="5%" valign="top"><fmt:message key="dbcdcplugin.text_label" />:&nbsp;*</td>
					<td width="95%"><textarea cols="120" rows="20" wrap="virtual" name="exampletext"><c:out value="${exampleText}"/></textarea></td>
				</tr>
				<tr>
					<td colspan="2" style="padding-top: 10px"><input type="submit" value="<fmt:message key="dbcdcplugin.button.save" />"/></td>
				</tr>
			</table>

		</admin:contentBox>

		<span class="jive-description">
			* <fmt:message key="dbcdcplugin.required" />
        </span>

        <input type="hidden" name="csrf" value="${csrf}">

    </form>

</body>
</html>

多语言配置dbcdc_i18n.properties

dbcdcplugin.title=&#x6570;&#x636E;&#x540C;&#x6B65;&#x63D2;&#x4EF6;
dbcdcplugin.options=Example Plugin Options
dbcdcplugin.saved.success=Settings saved successfully.
dbcdcplugin.required=Required fields.
dbcdcplugin.directions=Enter the Example Text
dbcdcplugin.text_label=XML
dbcdcplugin.text.missing=Please enter the dbcdc text!
dbcdcplugin.button.save=Save Settings

2.4、上传插件

在命令行下输入:mvn package,将会生成dbcdc-openfire-plugin-assembly.jar插件包,把插件包名改为dbcdc.jar,通过后台上传安装。
访问:http://localhost:9090/plugin-admin.jsp 上传。
在这里插入图片描述

2.4.1、访问servlet接口效果

在这里插入图片描述

2.4.2、访问Jersey接口效果

在这里插入图片描述

2.4.3、访问页面效果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1057482.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

撰写博客的工具记录

文章目录 前言TyporaPicgoGitee 免费图床ScreenToGifPointofix和Snipaste墨滴社区小结 前言 本文主要目的是记录和分析自己在写博客和相关文档时所用到的工具&#xff0c;单纯记录。按照一篇文章从0到发布的场景进行叙述。 Typora Typora是一款Markdown编辑器。Markdown的优…

游戏制作资源推荐

教程 创建僵尸第一人称射击游戏 | 虚幻引擎 5 初学者教程https://www.youtube.com/watch?vqOam3QjGE8g ​​​​​​​ 虚幻商城免费资产 人物资产 各种角色应有尽有 关键词&#xff1a;paragon &#xff1b;推荐程度&#xff1a;三颗星

C. MEX Repetition

题目&#xff1a;样例&#xff1a; 输入 5 1 2 1 3 1 0 1 3 2 2 0 2 5 5 1 2 3 4 5 10 100 5 3 0 4 2 1 6 9 10 8输出 1 2 0 1 2 1 2 3 4 5 0 7 5 3 0 4 2 1 6 9 10 思路&#xff1a; 从题目和样例中&#xff0c;我们可以知道&#xff0c;从一个数组中&#xff0c;按照包括0的自…

leetCode 121. 买卖股票的最佳时机 贪心算法

给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的最大利润。…

2023年汉字小达人市级比赛在线模拟题来了,四种练习助力好成绩

2023年第十届汉字小达人比赛区级自由报名活动已于9月30日结束&#xff0c;尽管最终晋级市级比赛的名单还需要在11月初发布&#xff08;有一些学校的校级选拔还没结束&#xff09;&#xff0c;但是许多小朋友已经开始准备市级比赛了。 根据往年的经验&#xff0c;实际比赛也是在…

软断言你也学不会

断言是测试用例的一部分&#xff0c;也是测试工程师开发测试用例的核心。断言通常集成在单元测试和集成测试中&#xff0c;断言分为硬断言和软断言。 硬断言是我们狭义上听到的普通断言:当用例运行后得到的[实际]结果与预期结果不匹配时&#xff0c;测试框架将停止测试执行并抛…

华为云云耀云服务器L实例评测|ClickHouse部署及压测

文章目录 前言&#x1f4e3; 1.前言概述&#x1f4e3; 2.安全设置&#x1f4e3; 3.ClickHouse安装✨ 3.1 申请服务器✨ 3.2 安装前准备✨ 3.3 RPM安装包✨ 3.4 配置文件✨ 3.5 使用ClickHouse &#x1f4e3; 4.ClickHouse压测✨ 4.1 下载数据✨ 4.2 解压数据✨ 4.3 创建数据库和…

(c++)类和对象 下篇

目录 1.再次了解构造函数 2. Static成员 3. 友元 4. 内部类 5.匿名对象 6.拷贝对象时的一些编译器优化 1.再次了解构造函数 1.1 构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值。 class Date { pub…

火山引擎 ByteHouse:如何提升 18000 节点的 ClickHouse 可用性?

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 ClickHouse 是业内被广泛使用的 OLAP 引擎。当集群规模过大时&#xff0c;ClickHouse 则面临使用局限性的问题。如何提升 ClickHouse 的可用性&#xff0c;成为困扰…

Python实时采集Windows CPU\MEMORY\HDD使用率

文章目录 安装psutil库在Python脚本中导入psutil库获取CPU当前使用率&#xff0c;并打印结果获取内存当前使用率&#xff0c;并打印结果获取磁盘当前使用情况&#xff0c;并打印结果推荐阅读 要通过Python实时采集Windows性能计数器的数据&#xff0c;你可以使用psutil库。psut…

怎么通过portainer部署一个vue项目

这篇文章分享一下今天通过docker打包vue项目&#xff0c;并使用打包的镜像在portainer上部署运行&#xff0c;参考了vue-cli和docker的官方文档。 首先&#xff0c;阅读vue-cli关于docker部署的说明 vue-cli关于docker部署的说明https://cli.vuejs.org/guide/deployment.html#…

SpringCloudAlibaba 相关组件的学习一

目录 前言 系统架构演变 1、单体架构 2、垂直架构 3、分布式架构 4、SOA架构 5、微服务架构 一、微服务架构的介绍 1、微服务架构的常见问题 2 微服务架构的常见概念 2.1 服务治理 2.2 服务调用 2.3 服务网关 2.4 服务容错 2.5 链路追踪 3、微服务架构的常用解决…

第2篇 机器学习基础 —(1)机器学习方式及分类、回归

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。机器学习是一种人工智能的分支&#xff0c;它使用算法和数学模型来使计算机系统能够从经验数据中学习和改进&#xff0c;而无需显式地编程。机器学习的目标是通过从数据中发现模式和规律&#xff0c;从而使计算机能够自动进…

黑马mysql教程笔记(mysql8教程)基础篇——数据库相关概念、mysql安装及卸载、数据模型、SQL通用语法及分类(DDL、DML、DQL、DCL)

参考文章1&#xff1a;https://www.bilibili.com/video/BV1Kr4y1i7ru/ 参考文章2&#xff1a;https://dhc.pythonanywhere.com/article/public/1/ 文章目录 基础篇数据库相关概念&#xff08;数据库DataBase&#xff08;DB&#xff09;、数据库管理系统DataBase Management Sy…

25种ACM模式输入输出模板,支持C++、Java、Python、Go、JS版本

很多录友苦于不熟悉 ACM 输入输入结构&#xff0c;在笔试和面试的时候&#xff0c;处理数据输入输出就花费了大量的时间&#xff0c;以至于算法题没写完&#xff0c;甚至是 根本就写不对输入输出的方式。 下面&#xff0c;我针对常见的25种 ACM输入与输出方式&#xff0c;给大…

Mojo 正式发布,Rust 能否与之匹敌?

9 月 7 日&#xff0c;Modular 公司宣布正式发布 Mojo&#xff1a;Mojo 现在已经开放本地下载——初步登陆 Linux 系统&#xff0c;并将很快提供 Mac 与 Windows 版本。据介绍&#xff0c;Mojo 最初的目标是比 Python 快 35000 倍&#xff0c;近日该团队表示&#xff0c;Mojo 将…

Linux--网络编程-字节序

进程间的通信&#xff1a; 管道、消息队列、共享内存、信号、信号量。 特点&#xff1a;都依赖于linux内核。 缺陷&#xff1a;无法多机通信。 一、网络编程&#xff1a; 1、地址&#xff1a;基于网络&#xff0c;ip地址端口号。 端口号作用&#xff1a; 一台拥有ip地址的主机…

完善多云平台软件体系,VMware再探索下一代企业IT架构

软件定义计算是由云计算兴起后带动的新一代企业IT架构。IDC定义的软件定义计算软件市场主要包括虚拟化软件、云系统软件和容器基础架构软件三个子市场&#xff0c;它们构成了支撑传统应用和云原生应用的软件定义计算平台&#xff0c;是构建云计算平台不可缺少也是最重要的基础架…

【计算机网络】HTTP协议详解(举例解释,超级详细)

文章目录 一、HTTP协议简单介绍 1、1 什么是HTTP协议 1、2 再次理解“协议” 二、HTTP请求 2、1 HTTP的工作过程 2、1、1 demo代码 2、2 URL 介绍 2、2、1 urlencode 和 urldecode 2、3 HTTP 请求格式 三、HTTP响应 3、1 响应demo 3、2 HTTP 响应格式 四、HTTP 请求和响应中的…

古记事法:Windows 下 16 位汇编环境搭建指南(DOSBox-X 篇)

文章目录 参考环境DOSBox-XWOWWindows On Windows 产生的原因Windows On Windows 的工作原理WOW16 的结束与 WOW64 的未来 在现代操作系统中运行 16 位应用程序DOSBox-X 16 位汇编环境的搭建应用准备挂载自动挂载dosbox-x.conf配置工具 参考 项目描述搜索引擎Bing、GoogleAI 大…