主頁 >  其他 > 訊息中間件MQ及ActiveMQ介紹

訊息中間件MQ及ActiveMQ介紹

2021-10-24 08:56:06 其他

前言

本篇文章會首先介紹MQ的概念,及核心概念及核心設計來理解出為什么需要訊息中間件,訊息中間間的作用,然后會接著介紹常用的activeMq的安裝,以及在spring中集成,一些比較常用的命令,

無論是在傳統還是互聯網中,都是協作的,系統之間有聯系,系統之間需要交流的方式分為兩種同步呼叫和異步呼叫,對應起來馬上回應和延時回應

對于同步和異步效果對比 上來說:

  • 同步-串行:

下單過后 需要等待所有服務完成,才能完成資料

缺點:耗時比較長 180ms

  • 異步-并行

利用執行緒池異步方式處理,降低處理時間

缺點是:高耦合、需要執行緒池管理, 寫訂單服務代碼 需要把所有的物流服務,,,都和訂單服務耦合起來

  • 異步-MQ

對應起來mq系統做通知得作用,所有服務訂閱,通知需要得服務

最后達到異步解耦得效果

通過訊息中間件可以達到異步解耦所有系統得效果,

訊息中間件MQ

概述

MQ(Message Queue)訊息佇列,是基礎資料結構中“先進先出”的一種資料結構,一般用來解決應用解耦,異步訊息,流量削峰等問題,實作高性能,高可用,可伸縮和最終一致性架構,

特點:

  • 利用 高效可靠得訊息傳遞機制 進行平臺無關的資料交流;
  • 并基于資料通信來進行分布式系統的集成;
  • 通過提供訊息傳遞和訊息排隊模型,它可以在分布式環境下擴展行程間通信;

訊息中間件的應用場景

跨系統資料傳遞、高并發流量削峰(緩沖)、資料異步處理、系統解耦,,,等等

常用的訊息中間件

ActiveMq、RabbitMq、Kafka、RoctetMq

對于message-Queue訊息中間件中的訊息對應的是資料物件,有可能是服務這些,

為什么要用Queue:也是來源于佇列的特性先進先出,不用堆疊這些結構,訊息是有順序,有時間先后的,

訊息中間件設計

本質

一種具備接收請求、保存資料、發送資料等功能的網路應用,和一般網路應用程式的區別是它負責資料的接收和傳遞,所以性能一般高于普通程式,

核心構成

協議、持久化機制、訊息分發機制、高可用設計、高可靠設計,

它因為需要接受保存發送資料,有了幾個核心機制, 所有的中間件都會包括這幾個構成,

協議

協議是計算機之間通信時共同遵從一組約定,都遵從相同的約定,計算機之間才能相互交流,是對資料格式和計算機之間交換資料時必須遵守的規則的正式描述,

協議三要素:

  • 語法:即資料與控制資訊的結構或格式,
  • 語意:即需要發出何種控制資訊,完成何種動作以及做出何種回應;
  • 時序:即事件實作順序的詳細描述,

也就是計算機之間相互交流約定的術語,

協議三要素舉例:
語法: http規定了請求報文和回應報文的具體格式, 
語意:客戶端主動發起的操作稱為請求;
時序:— 個請求對應— 個回應

至于在訊息中間件中不用http,大家肯定能想到,http的訊息頭也好,還是cookie等等欄位,太繁雜了,導致效率不高,而訊息中間件業務場景比較專一,所以不需要這種重協議,不用什么都考慮到,

AMQP協議

AMQP,即Advanced Message Queuing Protocol,一個提供統一訊息服務的應用層標準高級訊息佇列協議,是應用層協議的一個開放標準,為面向訊息的中間件設計,基于此協議的客戶端與訊息中間件可傳遞訊息,并不受客戶端/中間件不同產品,不同的開發語言等條件的限制,Erlang中的實作有RabbitMQ等,

特性:

事務支持、持久化支持、出生金融行業、在可靠訊息處理上具備天然的優勢,

MQTT協議

MQTT協議訊息佇列遙測傳輸是IBM開發的一個即時通訊協議,物聯網系統架構中的重要組成部分,

MQTT(訊息佇列遙測傳輸)是ISO 標準(ISO/IEC PRF 20922)下基于發布/訂閱范式的訊息協議,它作業在 TCP/IP協議族上,是為硬體性能低下的遠程設備以及網路狀況糟糕的情況下而設計的發布/訂閱型訊息協議,為此,它需要一個訊息中間件 ,

MQTT是一個基于客戶端-服務器的訊息發布/訂閱傳輸協議,MQTT協議是輕量、簡單、開放和易于實作的,這些特點使它適用范圍非常廣泛,在很多情況下,包括受限的環境中,如:機器與機器(M2M)通信和物聯網(IoT),其在,通過衛星鏈路通信傳感器、偶爾撥號的醫療設備、智能家居、及一些小型化設備中已廣泛使用,

特性:

輕量、結構簡單、傳輸快、沒有事務支持、沒有持久化相關設計

應用場景:

適用于計算能力有限、低帶寬、網路不穩定的場景,

Open message協議

Open message是近一兩年由阿里發起、與雅虎、滴滴出行、Streamlio等公司共同參與創立的分布式訊息中間件、流處理領域的應用開發標準,是國內首個在全球范圍內發起的分布式訊息領域國際標準,

特性:

結構簡單、決議快、有事務設計、有持久化設計

Kafka協議

kafka協議是基于TCP的二進制協議,訊息內部是通過長度來分隔,由一些基本資料型別組成,Kafka專有協議

特性

結構簡單、決議快、無事務設計、有持久化設計,

持久化

持久化是將程式資料在持久狀態和瞬時狀態間轉換的機制,通俗的講,就是瞬時資料(比如記憶體中的資料,是不能永久保存的)持久化為持久資料(比如持久化至資料庫中,能夠長久保存),

常用的持久化方式就兩種:

一是在磁盤中,二是在檔案系統中,

大部分訊息中間支持的是檔案系統中,在資料庫中支持比較重,并且繁雜

訊息分發

產生訊息分發策略的原因

也是在于 消費的方式 服務在去處理時,是多種多樣的

需要不同系統上進行消費,然后以及在業務場景二中,并不需要這么繁雜

需要一個確認機制,

常見的分發策略

  • 發布訂閱: 發一次資料,被所有訂閱的服務都收到
  • 輪詢分發: 發一條訊息,根據服務進行分發資料,有些是按權重進行輪詢
  • 公平分發:一般是權重進行公平分發
  • 重發:重發概念,需要有一個有一個訊息確認機制,來保證資料安全
  • 訊息拉取:由服務決定,而不是進行分發,服務想要時去拉取

高可用

“高可用性”(High Availability)通常來描述一個系統經過專門的設計,從而減少停工時間,而保持其服務的高度可用性,

在這里描述的是指產品在規定的條件和規定的時刻或時間區間內處于可執行規定功能狀態的能力,當業務量大時,一臺訊息中間件服務器可能無法滿足需求,所以需要訊息中間件能夠部署集群,達到高可用的目的,

主從方案共享資料的方式

通過共享資料方式來保證資料的一致性,

Master-Slave主從同步部署方式

也是只能在主節點進行操作資料

Blocker-Cluster多主從集群同步部署方式

Blocker-Cluster多主從集群轉發部署方式

將資料進行分開,

高可靠

最主要資料不能丟失

高可靠性是指系統可以無故障地持續運行,比如— 個系統從來不崩潰、報錯,或者崩潰、
報錯的幾率較低,那就是高可靠,
在高并發業務場景下,如果不能保證系統的高可靠,那造成的損失將會非常嚴重,

  • 保證訊息中間件的高可靠性,可以從以下幾方面考慮
  • 訊息傳輸可靠:通過協議來保證系統間資料決議的正確性,
  • 訊息存盤可靠:通過持久化來保證訊息的存盤可靠性

ActiveMQ

ActiveMQ是Apache出品的,比較經典的訊息中間件,

官網地址:activemq.apache.org

從官網介紹能很好地獲知 ActiveMQ 的用處:
Apache ActiveMQ? is the most popular open source, multi-protocol, Java-based messaging
server. It supports industry standard protocols so users get the benefits of client choices across a
broad range of languages and platforms. Connectivity from C, C++, Python, .Net, and more is
available. Integrate your multi-platform applications using the ubiquitous AMQP protocol.
Exchange messages between your web applications using STOMP over websockets. Manage your
IoT devices using MQTT. Support your existing JMS infrastructure and beyond. ActiveMQ offers
the power and flexibility to support any messaging use-case.
一款用 Java 開發的、開源的、支持多種協議的、非常流行的訊息服務(訊息中間件),因為它的支持多協議,支持工業標準的協議,所以我們可以跨平臺、跨語言來使用它,
  • AMQP工業標準協議進行多平臺應用集成;
  • Web應用可基于websocketSTOMP協議與ActiveMQ直接互動
  • 物聯網設備用MQTT協議
  • 基于JMS的已有基礎設施也支持
  • 還有更多
當前有兩個版本: ActiveMQ 5 "Classic" ActiveMQ Artemis ( 下一代版本 )

ActiveMQ Artemis 是高性能目標為非阻塞的版本,基于事件驅動,這里介紹是 ActiveMQ 5 "Classic" 經典版本

ActiveMQ作為一個老牌的訊息中間件,其提供了詳細的官方檔案,

active mq官方檔案

在官方檔案中

包含了一些學習目錄檔案,包含了使用

以及包含了 特性 以及使用說明等等

ActiveMQ常用的應用場景

  • 用AMQP工業標準協議進行多平臺應用集成;
  • Web應用可基于websocket的stomp協議與ActiveMQ直接互動,
  • 物聯網設備MQTT協議
  • 基于JMS的已有基礎設施也支持
  • 還有一些更多

ActiveMQ安裝

ActiveMQ是用JAVA開發的,跨平臺的,開箱即可使用

環境準備
  • 虛擬機軟體:Oracle VM VirtualBox 下載地址:https://www.virtualbox.org/wiki/Downloads
  • Linux: Centos 7 CentOS-7-x86_64-Minimal-1810.iso 阿里云鏡像下載地址:https://mirrors.aliyun.com/centos/7.6.1810/isos/x86_64/
  • Jdk 8 jdk-8u221-linux-x64.rpm

安裝包對應下載:https://activemq.apache.org/components/classic/download/

也可在linux機器上直接下載:

wget –c http://mirror.bit.edu.cn/apache/activemq/5.15.9/apache-activemq-5.15.9- bin.tar.gz

安裝

  • 創建安裝目錄
mkdir /usr/activemq
  • 解壓安裝包到安裝目錄
tar -zxvf apache-activemq-5.15.9-bin.tar.gz -C /usr/activemq
  • 為方便配置時書寫,創建軟鏈接
ln -s /usr/activemq/apache-activemq-5.15.9 /usr/activemq/latest
  • 熟悉activemq的目錄構成:

啟停
啟動
cd /usr/activemq/latest/bin
作為前臺行程啟動
./activemq console
作為后臺守護行程啟動
./activemq start
啟動輸出
INFO: Loading '/usr/activemq/apache-activemq-5.15.9//bin/env' INFO: Using java '/usr/bin/java' INFO: Starting - inspect logfiles specified in logging.properties and log4j.properties to get details INFO: pidfile created : '/usr/activemq/apache-activemq- 5.15.9//data/activemq.pid' (pid '14887')
啟動成功檢測
訪問管理控制臺: http://ip:8161/admin 如果防火墻阻止了,請看下面防火墻開發埠
ActiveMQ 的管理頁面默認開啟了身份校驗:
賬號: admin
密碼: admin
或在啟動 Console 或 日志檔案( data/activemq.log )中看到日志輸出:
Apache ActiveMQ 5.15.9 (localhost, ID:ntbk11111-50816-1428933306116-0:1) started | org.apache.activemq.broker.BrokerService | main
或用 jps 命令查看
[root@localhost latest]# jps 25778 activemq.jar 25805 Jps
停止
./activemq stop
了解 activemq 命令的用法(快速了解一下)
./activemq

瀏覽用法說明資訊

防火墻開放 ActiveMQ 的埠
#Web管理埠默認為8161,通訊埠默認為61616
 firewall-cmd --zone=public --add-port=8161/tcp --permanent
 firewall-cmd --zone=public --add-port=61616/tcp --permanent
重啟防火墻
systemctl restart firewalld.service
可以直接關閉防火墻
systemctl stop firewalld 
systemctl disable firewalld
Linux 服務安裝
參考安裝連接
  • 以普通用戶activemq 身份來運行
useradd activemq 
chown -R activemq:users /usr/activemq
  • 創建全域默認的組態檔,并配置activemq
cp /usr/activemq/latest/bin/env /etc/default/activemq
sed -i '~s/^ACTIVEMQ\_USER=""/ACTIVEMQ\_USER="activemq"/' 
/etc/default/activemq
編輯 activemq 組態檔,進行如下配置( 生產環境需要考慮配置
Confifigure the java heap to a size suitable to your system environment and usage
Consider to move the folders “data”, “tmp” and “conf” out of the installation path
vim /etc/default/activemq
配置內容如下所示:
# Active MQ installation dirs # ACTIVEMQ_HOME="<Installationdir>/" 
# ACTIVEMQ_BASE="$ACTIVEMQ_HOME" # ACTIVEMQ_CONF="$ACTIVEMQ_BASE/conf"
 # ACTIVEMQ_DATA="$ACTIVEMQ_BASE/data" # ACTIVEMQ_TMP="$ACTIVEMQ_BASE/tmp" 
# Set jvm memory configuration (minimal/maximum amount of memory) ACTIVEMQ_OPTS_MEMORY="-Xms64M -Xmx1G"
修改權限模式
chmod 644 /etc/default/activemq
  • 安裝啟動腳本
ln -snf /usr/activemq/latest/bin/activemq /etc/init.d/activemq
  • 激活啟動服務
# RHEL 
chkconfig --add activemq 
chkconfig activemq on
systemctl enable activemq
  • 手動啟動服務
systemctl start activemq

activeMQ管理臺

自帶的管理臺,在瀏覽器中訪問http://服務IP:8161/admin即可進入

  • broker 展示的實體 MQ的資訊

  • queue 佇列中資料資訊 ,包含入隊 訊息,出隊資訊,以及 消費者資訊
  • topics 發布訂閱的主題資訊

  • 訂閱者 subscribers

以及后面的訂閱者網路連接等等,都是需要使用到的

send a jms message 控制臺

ActiveMQ 配置

這里面包含 webapps 和組態檔,以及 data 日志檔案 以及資料檔案地,

組態檔

web服務控制臺 的 組態檔 jetty.xml

  • 打開有埠號等的配置,沿用spring的配置,包含安全配置,埠號配置

  • real.properties 配置對應的用戶資訊

以及 group.properties 對于訊息的配置 , log4j.properties 配置日志 檔案,

ActiveMQ使用

直接添加maven依賴即可,其實作在基本的使用方式都是采用這種方式,從而達到引入 引入activemq-all.jar 的目的

<dependency>
   <groupId>org.apache.activemq</groupId> 
   <artifactId>activemq-all</artifactId>
    <version>5.15.9</version>
 </dependency>

使用方式

創建一個消費者,進行 請求消費資料,這是最原始的,但我們一般不使用這種方式

try {
     // brokerURL 
    // http://activemq.apache.org/connection-configuration-uri.html 
	// 1、創建連接工廠 
	 connectionFactory = new ActiveMQConnectionFactory(this.brokerUrl); 
	// 2、創建連接物件 
	  conn = connectionFactory.createConnection(); conn.start(); 
	  // 一定要啟動 
	  // 3、創建會話(可以創建一個或者多個session) 
	  session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE); 
	  // 4、創建訊息消費目標(Topic or Queue)
	  Destination destination = session.createQueue(destinationUrl); 
	  // 5、創建訊息消費者 http://activemq.apache.org/destination- options.html
	  consumer = session.createConsumer(destination); 
	  // 6、接收訊息(沒有訊息就持續等待)
	  Message message = consumer.receive(); 
	  if (message instanceof TextMessage) {
	  System.out.println("收到文本訊息:" + ((TextMessage) message).getText()); 
	  } else { 
	  System.out.println(message);
	  }consumer.close(); 
	  session.close();
	  conn.close();

以及生產者

public class Producer {
	public static void main(String[] args) {
		new ProducerThread("tcp://mq.study.com:61616", "queue1").start();
		new ProducerThread("tcp://mq.study.com:61616", "queue1").start();
	}

	static class ProducerThread extends Thread {
		String brokerUrl;
		String destinationUrl;

		public ProducerThread(String brokerUrl, String destinationUrl) {
			this.brokerUrl = brokerUrl;
			this.destinationUrl = destinationUrl;
		}

		@Override
		public void run() {
			ActiveMQConnectionFactory connectionFactory;
			Connection conn;
			Session session;

			try {
				// 1、創建連接工廠
				connectionFactory = new ActiveMQConnectionFactory(brokerUrl);
				connectionFactory.setUseAsyncSend(true);
				// 2、創建連接
				conn = connectionFactory.createConnection();
				conn.start(); // 一定要start

				// 3、創建會話(可以創建一個或者多個session)
				session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);

				// 4、創建訊息發送目標 (Topic or Queue)
				Destination destination = session.createQueue(destinationUrl);

				// 5、用目的地創建訊息生產者
				MessageProducer producer = session.createProducer(destination);
				// 設定遞送模式(持久化 / 不持久化)
				producer.setDeliveryMode(DeliveryMode.PERSISTENT);

				// 6、創建一條文本訊息
				String text = "Hello world! From: " + Thread.currentThread().getName() + " : "
						+ System.currentTimeMillis();
				TextMessage message = session.createTextMessage(text);

				// 7、通過producer 發送訊息
				System.out.println("Sent message: " + text);
				CountDownLatch cdl = new CountDownLatch(1);

				((ActiveMQMessageProducer) producer).send(message, new AsyncCallback() {

					@Override
					public void onException(JMSException exception) {
						// TODO Auto-generated method stub

					}

					@Override
					public void onSuccess() {
						try {
							System.out.println(Thread.currentThread().getName() + " 異步發送完成:messageId: "
									+ message.getJMSMessageID() + " " + text);
						} catch (JMSException e) {
						}
					}
				});

				// cdl.await();
				// 8、 清理、關閉連接
				session.close();
				conn.close();
			} catch (JMSException e) {
				e.printStackTrace();
			}
		}
	}
}

在topic服務器上,會將訊息單獨發送 ,為每個消費者都維護了一個佇列,

在使用程序中

  • 在發布訂閱模式下,如果在訂閱在發布之后,不應該收到訊息,
  • 持久訂閱 MQ登記有名的訂閱,消費者 掛了,會持久等待

spring boot 中使用ActiveMQ

參考包中

https://docs.spring.io/spring-boot/docs/2.1.6.RELEASE/reference/html/boot-features-messaging.h
tml
引入starter : spring-boot-starter-activemq
<dependency> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-activemq</artifactId> 
</dependency>

配置activemq broker連接引數 (application.yml)

spring: 
   activemq: 
    broker-url: tcp://mq.study.com:61616 
    #user: admin
    #password: secret
可配置引數有 spring.activemq.* spring.jms.*

使用方式很簡單

@Autowired
	private JmsTemplate jmsTemplate;

	@PostConstruct
	public void sendMessage() {
		// Send a message with a POJO - the template reuse the message converter
		System.out.println("Sending an email message.");
		jmsTemplate.convertAndSend("mailbox", new Email("info@example.com", "Hello"));
	}

	public static void main(String[] args) {
		SpringApplication.run(Producer.class, args);
	}

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/333623.html

標籤:其他

上一篇:Rabbitmq的分布式事務解決方案(十二)

下一篇:Java面試——RabbitMQ系列總結

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more