主頁 >  其他 > zookeeper隨堂筆記

zookeeper隨堂筆記

2022-02-24 08:09:55 其他

學習目標:

  1. 什么是zookeeper
  2. 應用場景
  3. 基本的操作
    1. 安裝部署
    2. shell客戶端
    3. java端
  4. 基本原理
    1. 選舉機制
    2. 資料一致性
    3. 資料的讀寫流程

1 zookeeper簡介

zookeeper是一個底層的集群協調工具,(比如:NN和DN之間的狀態感應;監控 通知)!

具備基本的功能有 ,記錄用戶的狀態資料 (寫), 回傳用戶的資料(讀) ,監控和通知,zookeeper為了高可用和安全性是一個集群! 3臺(每個節點的資料完全一致)!

2 應用場景

  • 寫資料
  • 讀取資料
  • 監控通知

2.1 服務狀態感知

2.2 分布式鎖

2.3 分布式配置同步

2.4 統一域名

分布式中統一CMD指令

分布式中服務器的狀態感知

3 操作

3.1 安裝

zookeeper在部署的時候選擇奇數臺!要求zk集群半數以上的機器在線才能正常作業!

上傳解壓

配置

  1. 在zk安裝目錄下 創建檔案夾 zkData mkdir zkData /opt/apps/zookeeper-3.4.6/zkData
  2. 修改conf/下的配置模板組態檔名 mv zoo_sample.cfg zoo.cfg
  3. vi zoo.cfg
    dataDir=/opt/apps/zookeeper-3.4.6/zkData
    
    # Set to "0" to disable auto purge feature
    #autopurge.purgeInterval=1
    server.1=linux01:2888:3888
    server.2=linux02:2888:3888
    server.3=linux03:2888:3888
  4. 在zkData檔案夾下創建myid檔案 echo 1 > zkData/myid

同步安裝包

scp -r  zookeeper-3.4.6/  linux02:$PWD
scp -r  zookeeper-3.4.6/  linux03:$PWD

修改各個節點myid的值 linux02【2】 linux03【3】

啟動集群

在各個節點上啟動ZK服務

/opt/apps/zookeeper-3.4.6/bin/zkServer.sh  start

查看行程 jps

[root@linux01 bin]# jps
1697 QuorumPeerMain
1720 Jps

查看集群狀態 在每個節點執行

/opt/apps/zookeeper-3.4.6/bin/zkServer.sh  status

-------------------------------------------------------
Mode: follower

Mode: leader

Mode: follower

3.2 撰寫一鍵啟動腳本

#!/bin/bash
# zk啟停腳本 
for hostname in linux01  linux02  linux03
do 
echo "連接${hostname}... ...正在執行 $1"
ssh ${hostname} "source  /etc/profile ;/opt/apps/zookeeper-3.4.6/bin/zkServer.sh  $1 ;exit"
done 

3.3 shell操作

zookeeper中記錄資料以Tree節點的形式存盤資料的/類似于目錄樹!

目錄叫znode : 節點的組織資料是 K V

基本操作指令

# 客戶端連接 
bin/zkCli.sh 連接到本地zk服務
bin/zkCli.sh -server  linux02:2181  連接到執行節點的服務
quit  退出客戶端      ctrl+c
-------------------------------------------
help 幫助命令  查看系統支持的所有的命令
ZooKeeper -server host:port cmd args
        stat path [watch]
        set path data [version]
        ls path [watch] * 
        delquota [-n|-b] path
        ls2 path [watch]  * 
        setAcl path acl
        setquota -n|-b val path
        history 
        redo cmdno
        printwatches on|off
        delete path [version]  * 
        sync path
        listquota path
        rmr path  * 
        get path [watch]
        create [-s] [-e] path data acl  * 
        addauth scheme auth
        quit   * 
        getAcl path
        close   * 
        connect host:port

-------------------------------------------------------------------
創建節點  節點必須以/開頭  (路徑必須是絕對路徑)
--   create [-s] [-e] path data acl
create  /a  1 
create  /b  2 
create  /a/a1 11
create  /a/a2 22
create  /a/a3 33 
[-s] 在節點后面添加一個自增的id  防止節點名重復而創建失敗
[-e]  創建的節點是臨時節點  , 只在當前連接中有效
------節點分類-----
--臨時節點
     臨時有序   -e
     臨時無序   -e  -s
--永久節點
     永久有序    -s
     永久無序   默認
注意: 節點的創建不能層級創建
查看節點串列 
ls    /a 
ls2   /a  顯示資料版本 , 事務id 創建時間等資訊

修改資料 
set  /a  123
獲取資料 
get  /a 
洗掉節點  
delete   /a  只能洗掉空節點
rmr      /a  可以洗掉任意節點 

監聽和通知

事件 : 觸發了某種事件 通知

  • 節點資料的變化
  • 子節點個數的變化
  1. ls path [watch] 監控指定路徑下資料的變化
  2. get path [watch] 監控指定路徑資料的變化

注意: 監控和通知只能1次

打開兩個zk客戶端
1) 一個監控   2) 一個修改資料 

#  子節點個數變化
視窗01  :  ls  /   watch  
          ->(WatchedEvent state:SyncConnected type:NodeChildrenChangedpath:/)
視窗02  :  rmr  /a000000004 
---------------------------------------------------------------------------
#  節點資料變化
視窗01  :   get  /b   watch  
          ->(WatchedEvent state:SyncConnected type:NodeDataChanged path:/b)
視窗02  :  set /b   321

3.4 java操作

  • 添加依賴
  • 獲取zk客戶端
  • 呼叫API
  • 釋放資源

添加依賴

<dependency>
  <groupId>org.apache.zookeeper</groupId>
  <artifactId>zookeeper</artifactId>
  <version>3.4.6</version>
</dependency>

入門示例-[獲取連接\創建節點]

package com.doitedu.zk.cli;

import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.ZooDefs;
import org.apache.zookeeper.ZooKeeper;
import java.io.IOException;
/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description TODO
 */
public class Demo01 {
    public static void main(String[] args) throws Exception {
        // 獲取zk的客戶端
        /**
         * 引數一 zk的地址  host:port,host2:port
         * 引數二 連接的超時時間  毫秒
         * 引數三 連接成功后的監聽
         */
        ZooKeeper zk = new ZooKeeper("linux01:2181,linux02:2181,linux03:2181", 3000, null);
        // 呼叫API
        //1  創建節點
        /**
         * 引數1   路徑
         * 引數2   資料 值 位元組陣列
         * 引數3   權限
         * 引數4   節點型別  1 2 3 4
         */
        zk.create("/doitedu" , "JINGYINGDOIT30_".getBytes() , ZooDefs.Ids.OPEN_ACL_UNSAFE , CreateMode.EPHEMERAL_SEQUENTIAL);
      //  System.out.println(zk);
        //釋放資源
        Thread.sleep(8000);
        zk.close();

    }
}

zookeeper-Java-API使用

package com.doitedu.zk.cli;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.data.Stat;
import java.util.List;

/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description
 * 創建節點
 * 洗掉節點
 * 獲取值
 * 修改值
 * 遍歷子節點串列
 *   判斷節點是否存在
 */
public class ClientApiDemo {
    public static void main(String[] args) throws Exception {
        // 獲取客戶端物件
        ZooKeeper zk = ZookeeperUtil.getZookeeper();
        // testGetData(zk);
        //修改資料
        //testSetData(zk);
        //獲取子節點串列
        //testls(zk);
        // 只能洗掉空節點   遞回
       // zk.delete("/b" , -1);
       // 遞回洗掉節點
        ZookeeperUtil.rmr(zk,"/b") ;
        zk.close();
    }
    // 查看路徑下的子節點串列
    public static void testls(ZooKeeper zk) throws KeeperException, InterruptedException {
        List<String> ls = zk.getChildren("/", null);
        if(ls!=null && ls.size()>0){
            for (String name : ls) {
                System.out.println("節點的名字是:" + name);
                byte[] data = zk.getData("/" + name, null, null);
                System.out.println(new String(data));
            }
        }
    }
    // 更新資料
    public static void testSetData(ZooKeeper zk) throws KeeperException, InterruptedException {
        Stat stat = zk.setData("/b", "liulan".getBytes(), -1);
        // 如果更新成功Stat 不為null
        if(stat != null){
            testGetData(zk);
        }
    }

    // 獲取資料
    public static void testGetData(ZooKeeper zk) throws KeeperException, InterruptedException {

        byte[] data = zk.getData("/b", null, null);
        String str = new String(data);
        System.out.println(str);
    }
}

封裝工具類

package com.doitedu.zk.cli;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.ZooKeeper;
import java.io.IOException;
import java.util.List;
/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description TODO
 */
public class ZookeeperUtil {
    /**
     * 獲取指定zk集群的客戶端物件
     *   linux01  02  03
     * @return
     * @throws IOException
     */
    public  static ZooKeeper  getZookeeper() throws IOException {
        return  new ZooKeeper("linux01:2181,linux02:2181,linux03:2181", 3000, null);
    }

    /**
     * 洗掉任意節點
     * @param zk
     * @param path
     * @throws KeeperException
     * @throws InterruptedException
     */
    public static void  rmr(ZooKeeper zk , String path) throws KeeperException, InterruptedException {
        // 遍歷是否有子節點
        List<String> ls = zk.getChildren(path, null);
        // 有子節點
        if(ls!=null &&  ls.size() >0){
            // 洗掉子節點
            for (String name : ls) {
                //---遞回
                rmr(zk , path+"/"+name);
            }
        }
        //沒有子節點
        zk.delete(path , -1);
    }
}

監控和通知

  • 連接成功 監聽通知
  • 資料變化
  • 節點變化

例子

package com.doitedu.zk.cli;

import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;

import java.io.IOException;

/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description 連接物件獲取成功 事件通知
 */
public class TestWatcher01 {

    public static void main(String[] args) throws Exception {
        /**
         * 引數三  事件通知  監聽器
         *  在獲取物件的時候使用  當連接成功以后會  回呼一次process方法
         */
        ZooKeeper zk = new ZooKeeper("linux11:2181", 2000, new Watcher() {
            public void process(WatchedEvent event) {
                System.out.println("獲取連接成功......");
            }
        });
        System.out.println(zk);
        zk.close();


    }


}

----------------------------------------------------------------------
package com.doitedu.zk.cli;

import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;

/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description
 * 監聽節點資料的變化
 *   當監聽的節點的資料發生變化    通知客戶端  回呼process
 */
public class TestWatcher02 {

    public static void main(String[] args) throws Exception {
        /**
         * 引數三  事件通知  監聽器
         *  在獲取物件的時候使用  當連接成功以后會  回呼一次process方法
         */
        final ZooKeeper zk = new ZooKeeper("linux01:2181", 2000, null);
        // 獲取指定節點資料的時候  系結監聽器  監聽此節點資料的變化
        byte[] data = zk.getData("/b", new Watcher() {
            // /b節點資料變化就會執行這個方法   1次
            public void process(WatchedEvent event) {
                try {
                    System.out.println("/b的資料發生了變化....");
                    System.out.println(event.getType());
                    // 改變后的資料是
                    byte[] data1 = zk.getData("/b", this, null);
                    System.out.println("變化后的的資料是: "+new String(data1));
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }, null);
        System.out.println("變化以前的資料是: "+new String(data));

        Thread.sleep(Integer.MAX_VALUE);
        zk.close();
    }


}
-----------------------------------------------------------------------
package com.doitedu.zk.cli;

import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;

import java.util.List;

/**
 * @Date 2022/2/23
 * @Created by HANGGE
 * @Description
 * 監聽節點資料的變化
 *   當監聽的節點的資料發生變化    通知客戶端  回呼process
 */
public class TestWatcher03 {

    public static void main(String[] args) throws Exception {
        /**
         * 引數三  事件通知  監聽器
         *  在獲取物件的時候使用  當連接成功以后會  回呼一次process方法
         */
        final ZooKeeper zk = new ZooKeeper("linux01:2181", 2000, null);

        List<String> ls = zk.getChildren("/", new Watcher() {
            // 當 / 節點的子節點 被洗掉  添加 執行這個方法
            public void process(WatchedEvent event) {
                try {
                    System.out.println(event.getType());
                    List<String> ls2 = zk.getChildren("/", this);
                    System.out.println("變化后的節點有:"+ls2);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });

        System.out.println("當前的節點有: "+ls);


        Thread.sleep(Integer.MAX_VALUE);
        zk.close();
    }


}

4 原理基礎

4.1 選舉機制

在ZK中有三種狀態 ;

Leader: 優先負責寫資料

follower 存盤資料 參與選舉

observe 觀察者 不參與選舉 存盤資料

每個服務器都有一個唯一的myid標記

初始啟動選舉

  1. ZK服務啟動[linux01(myid=1)] , 發現集群中沒有Leader .進入到選舉狀態 ; 投自己一票
  2. myid=1的機器獲取1票 , 票數沒有過半, 不能當選leader
  3. linux01, 廣播投票結果
  4. linux02(myid=2)啟動 ,發現集群中沒有leader , 進入到選舉狀態
  5. 收到linux01的1票資訊 , 發現linux02的myid > linux01的myid ;投自己一票 ,廣播
  6. linux01收到廣播 ,發現自己的myid小 ; 改投lnux02 1票 , 廣播
  7. linux02 收到linux01的廣播 ,自己的票數為2 , 過半 ,切換leader狀態
  8. linux01 切換follower狀態
  9. linux03啟動 ,發現集群中有leader ;切換follower狀態

運行程序中選舉

注意: 要求整個集群中的資料是一致的! 有事務的保證! zxid事務id

1 先比較zxid的大小 , zxid大的優先當選

2 如果事務id一致 , 再比較myid

整個集群中有機器宕機 ,屬于不正常的狀態! 修復.........

資料一致性

zk中存盤資料以KV的形式 ; K是以節點的組織的 以/開頭

整個集群中所有的節點存盤一樣的資料

記錄的資料一般為狀態資料 ,配置資料 ,命令....資料量不大

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

標籤:其他

上一篇:flink如何利用checkpoint保證資料狀態一致性

下一篇:入門ClickHouse和Elasticsearch

標籤雲
其他(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