Dify本地安裝部署筆記

目錄

方式一【docker安裝】:

步驟 1:準備工作

步驟2: 克隆dify倉庫

步驟3:部署啟動dify

步驟 4:訪問 Dify

步驟5:升級dify

方式二【源碼安裝】:

步驟1. 硬件:最低安裝要求

步驟2: 業務服務前的3個服務

1. 安裝工具:

2. 安裝redis,wget,nginx,nodejs,npm等必備工具?

3. 啟動服務

步驟3: Clone Dify 代碼:

步驟4: 啟動前端,后端,和worker

步驟5:配置代理nginx

踩坑記錄:

踩坑: pyenv

踩坑:poetry工具

poetry install時一直提示Cannot install alibabacloud-tea因為?_cffi_backend找不到

安裝onnxruntime錯誤

Installing grpcio (1.67.1):?Failed??TimeoutError??????????????

踩坑: flask、postgreSQL

1. flask不存在:???????

2. postgreSQL Connection refused:postgresql沒有配置用戶密碼,也沒有啟動服務

解決辦法:

踩坑:root未定義


Dify 是一個讓你輕松構建 AI 應用的開源平臺,簡單來說就是給開發者打造的一站式AI應用開發工具。它主要有以下幾個特點:

  1. 簡單直觀:你可以通過圖形界面來創建和調試 AI 應用,幾分鐘就能發布。
  2. 上下文集成:可以用你自己的數據來進行文本預處理,無需深入了解技術細節。
  3. API 訪問:提供后臺服務,直接訪問 Web 應用或將 API 集成到你的項目中,不用擔心復雜的后臺架構和部署問題。
  4. 數據優化:通過圖形界面查看 AI 的運行日志,改進數據標注,不斷提升 AI 的表現。

Dify 兼容 Langchain,支持多種大語言模型(LLM)。目前支持的模型供應商包括 OpenAI、Azure OpenAI、Anthropic、Replicate、Hugging Face、ChatGLM、Llama2、MiniMax、訊飛星火、文心一言和通義千問等。

換句話說,Dify 就是一個幫你快速、高效地開發和優化 AI 應用的萬能工具箱。

方式一【docker安裝】:

步驟 1:準備工作

確保你已經安裝了 Docker 和 Docker Compose。如果沒有,請先安裝:

  1. Docker:可以從 Docker 官方網站(https://www.docker.com/get-started) 下載并安裝適合你操作系統的版本。
  2. Docker Compose:一般 Docker 會自帶 Docker Compose,如果沒有,你可以按照 Docker Compose 安裝指南(https://docs.docker.com/compose/install/) 進行安裝。

Docker的安裝不需要說了,雙擊安裝文件就行。已經安裝docker的情況下,安裝Docker Compose,可以在終端輸入下面的命令(如果不起作用,你需要安裝一下 Homebrew):

brew install docker-compose

Dify本地安裝可以用docker方式,和源碼編譯方式。

步驟2: 克隆dify倉庫

安裝dify并啟動:git clone https://github.com/langgenius/dify.git

用“訪達”打開一個桌面建立一個dify文件夾,然后雙擊以后就可以直接使用:

git clone https://github.com/langgenius/dify.git

它的效果等同于:

?cd ~/Desktopmkdir dify ?#?其中,mkdir是“make directory”的縮寫。
?
cd dify
?
git clone https://github.com/langgenius/dify.git

步驟3:部署啟動dify


# 進入 dify 源代碼的 docker 目錄,配置nginx端口,執行一鍵啟動命令
cd dify/docker
export EXPOSE_NGINX_PORT=8080
docker compose up -d

啟動后docker ps 可以看到以下容器

netstat -natp可以看到docker監聽的端口是8080,設置安全組開發8080端口

訪問 http://虛擬機ip:8080 ?根據情況輸郵箱,用戶名,密碼 完成本地注冊可以開始使用

等上一會兒你就會發現部署結果:

[+] Running 9/9
? Container docker-web-1 Started 1.0s
? Container docker-redis-1 Started 1.1s
? Container docker-weaviate-1 Started 0.9s
? Container docker-db-1 Started 0.0s
? Container docker-worker-1 Started 0.7s
? Container docker-api-1 Started 0.8s
? Container docker-nginx-1 Started 0.7s
? Container docker-sandbox-1 Started 0.7s
? Container docker-ssrf_proxy-1 Started 0.8

用下面的命令檢查一下是不是正常運行:

docker compose ps

你也可以打開docker的桌面應用,看看里面容器運行情況。

步驟 4:訪問 Dify

在瀏覽器輸入框里輸入:localhost/install,這是為了完成 Dify 的初始配置的。

稍等一會兒,就大功告成了。

步驟5:升級dify

進入 dify 源代碼的 docker 目錄,按順序執行以下命令:cd dify/docker
git pull origin main
docker compose down
docker compose pull
docker compose up -d
  1. 如果發現其他問題,建議直接GPT來解決。比如說端口沖突,還有環境變量錯誤之類的。實在不行,把容器什么的都刪除,按照流程重來一遍。
  2. 為什么有了Docker客戶端了,還要用Docker Compose,是不是多此一舉?要知道如果你下載其他GitHub項目很多的話,用`docker run`這種命令也可以安裝。這個就必須說Docker,它最大的強項是把軟件所有依賴都打包到了里頭,所以運行一個復雜的小項目會省掉很多本地配置。Docker 可以有效管理單個容器,但當你需要管理一個包含多個容器的復雜應用時,Docker Compose 就顯得尤為重要了。尤其我們初學者,如果你一開始的時候,總是使用`docker run`這種命令,你會在docker里面迷失的,會覺得難受。而Docker Compose就很舒服了。

Docker Compose實際上是圍繞一個docker-compose.yml 文件工作的,舉個例子:

# 沒有Docker Compose的時候,你需要通過終端輸入很多指令,一條一條run:
docker run -d --name db postgres
docker run -d --name web --link db:db my-web-app
# 但是你如果有docker-compose.yml 文件,如果像上面跑的數據庫和后端服務,一般里面是這樣的:
version: '3'
services:db:image: postgresenvironment:POSTGRES_PASSWORD: exampleweb:image: my-web-appdepends_on:- dbports:- "8000:8000"
# 直接輸入下面的指令就好:
docker compose up# 下載完dify客戶端以后,在docker的文件下面執行的就是這個命令:
docker compose up -d
這里的`-d`,指的是`啟動`,它是 detach 的縮寫,表示讓容器在后臺運行。使用`-d`選項運行容器時,命令會立即返回,你的終端不會被容器的輸出占用,這樣你可以繼續在同一個終端會話中執行其他命令。

方式二【源碼安裝】:

步驟1. 硬件:最低安裝要求

安裝 Dify 之前, 請確保你的機器已滿足最低安裝要求:CPU >= 2 Core,RAM >= 4 GiB

源碼安裝主要可以參考文檔:dify官網中文安裝說明

步驟2: 業務服務前的3個服務

官網給的安裝說明中只說了可以用docker啟動這3個服務: PostgreSQL / Redis / Weaviate

cd docker
cp middleware.env.example middleware.env
docker compose -f docker-compose.middleware.yaml up -d

在啟用業務服務之前,我們需要先部署 PostgreSQL / Redis / Weaviate(如果本地沒有的話),那么如果沒有docker,或者不想用docker怎么做呢?

1. 安裝工具:

Linux:用apt-get安裝,

sudo apt-get update

2. 安裝redis,wget,nginx,nodejs,npm等必備工具?

#安裝pg redis
sudo apt install redis-server wget postgresql postgresql-client -ysudo apt install nginx nodejs npm -ysudo wget https://github.com/weaviate/weaviate/releases/download/v1.27.12/weaviate-v1.27.12-linux-amd64.tar.gzsudo tar -zxf weaviate-v1.27.12-linux-amd64.tar.gz#安裝向量數據庫
sudo chmod +x weaviatesudo mv weaviate /opt
設置數據庫密碼:修改/etc/redis/redis.conf,添加:requirepass difyai123456

3. 啟動服務

# 啟動redis:service redis-server start# 啟動pg:service postgresql start?# 修改pg密碼:su - postgrespsqlCREATE DATABASE dify;ALTER USER postgres WITH PASSWORD 'difyai123456';quit;# 啟動weaviate:export PERSISTENCE_DATA_PATH=/var/lib/weaviate
export QUERY_DEFAULTS_LIMIT=25
export AUTHENTICATION_ANONYMOUS_ACCESS_ENABLED=false
export DEFAULT_VECTORIZER_MODULE=none
export CLUSTER_HOSTNAME=node1
export AUTHENTICATION_APIKEY_ENABLED=true
export AUTHENTICATION_APIKEY_ALLOWED_KEYS=WVF5YThaHlkYwhGUSmCRgsX3tD5ngdN8pkih
export AUTHENTICATION_APIKEY_USERS=hello@dify.ai
export AUTHORIZATION_ADMINLIST_ENABLED=true
export AUTHORIZATION_ADMINLIST_USERS=hello@dify.aicd /opt
nohup ./weaviate --host 0.0.0.0 --port '8080' --scheme http |tee ./weaviate.log 2>&1 &

MAC:用brew安裝,brew最好設置國內鏡像

brew install postgresql

步驟3: Clone Dify 代碼:

git clone?https://github.com/langgenius/dify.git
再按照文檔進行源碼安裝,文檔中如果執行poetry shell失敗的話以下命令要帶上poetry run,否則會報錯

poetry run flask db upgrade


步驟4: 啟動前端,后端,和worker

啟動前端

#啟動前端
export NEXT_PUBLIC_DEPLOY_ENV=DEVELOPMENT
export NEXT_PUBLIC_EDITION=SELF_HOSTED
export NEXT_PUBLIC_API_PREFIX=/console/api ?#不設置默認訪問http://localhost/console/api
export NEXT_PUBLIC_PUBLIC_API_PREFIX=/api ?#不設置默認訪問http://localhost/api
export NEXT_PUBLIC_SENTRY_DSN=
export NEXT_TELEMETRY_DISABLED=1
export NEXT_PUBLIC_UPLOAD_IMAGE_AS_ICON=false
export NEXT_PUBLIC_TEXT_GENERATION_TIMEOUT_MS=60000
export NEXT_PUBLIC_CSP_WHITELIST=
export NEXT_PUBLIC_TOP_K_MAX_VALUE=10
export NEXT_PUBLIC_INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH=4000
nohup npm run start &

啟動worker?

#啟動worker
#start backend
export CONSOLE_API_URL=
export APP_API_URL=
export WEB_SENTRY_DSN=
export NEXT_TELEMETRY_DISABLED=0
export TEXT_GENERATION_TIMEOUT_MS=60000
export CSP_WHITELIST=
export TOP_K_MAX_VALUE=10
export INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH=4000
cd /app/dify/api
nohup poetry run ?celery -A app.celery worker -P gevent -c 1 -Q dataset,generation,mail,ops_trace --loglevel INFO ./celery.log 2>&1 &

啟動后端?

nohup poetry run flask run --host 0.0.0.0 --port=5001 --debug |tee ./backend.log 2>&1 &

步驟5:配置代理nginx

這樣跑起來只適合本機訪問,如果要從公網訪問還要加一層nginx,我們在前面已安裝nginx,這里我們就配置nginx,讓其可以代理訪問dify

修改/etc/nginx/nginx.conf如下:

user www-data;
worker_processes auto;
pid /run/nginx.pid;
error_log /var/log/nginx/error.log;
include /etc/nginx/modules-enabled/*.conf;events {worker_connections 768;# multi_accept on;
}http {include ? ? ? /etc/nginx/mime.types;default_type ?application/octet-stream;log_format ?main ?'$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';access_log ?/var/log/nginx/access.log ?main;sendfile ? ? ? ?on;#tcp_nopush ? ? on;keepalive_timeout ?65;#gzip ?on;client_max_body_size 15M;include /etc/nginx/conf.d/*.conf;
}


修改文件 /etc/nginx/conf.d/default.conf

server {listen 8080;server_name _;location /console/api {proxy_pass http://127.0.0.1:5001;}location /api {proxy_pass http://127.0.0.1:5001;}location /v1 {proxy_pass http://127.0.0.1:5001;}location /files {proxy_pass http://127.0.0.1:5001;}location / {proxy_pass http://127.0.0.1:3000;}}

AI寫代碼
重啟nginx:systemctl restart nginx

通過命令netstat -natp 確認nginx確實監聽8080端口

訪問 http://虛擬機ip:8080 ?后續頁面訪問同方式一

踩坑記錄:

踩坑: pyenv

Pyenv下載包非常慢,直接用官網的python包安裝python

踩坑:poetry工具

  1. poetry install時一直提示Cannot install alibabacloud-tea因為?_cffi_backend找不到

    • 錯誤ERROR:?Invalid requirement: '_cffi_backend': Expected package name at the start of dependency specifier: _cffi_backend。

    • 解決辦法:一定要用poetry安裝cffi包才行,poetry add cffi?

  2. 安裝onnxruntime錯誤

    • 信息: Installing onnxruntime (1.21.0):?Failed

    • 解決辦法:版本不對,用pip安裝能成功,pip install onnxruntime -i https://pypi.tuna.tsinghua.edu.cn/simple/,查到對應的安裝成功的版本是1.19.2,指定版本安裝即可poetry add onnxruntime@1.19.2

  3. Installing grpcio (1.67.1):?Failed??TimeoutError??????????????

錯誤:The read operation timed out,在api目錄下pyproject.toml項目最后添加對應的國內鏡像

  1. [[tool.poetry.source]] 
    name = "tuna" 
    url = "https://pypi.tuna.tsinghua.edu.cn/simple/
    ??????并執行poetry lock,重新執行poetry install

踩坑: flask、postgreSQL

1. flask不存在:???????

解決:執行這個命令直接說flask不存在,根據上面步驟繼續執行poetry add flask,然后再次執行

2. postgreSQL Connection refused:postgresql沒有配置用戶密碼,也沒有啟動服務

sqlalchemy.exc.OperationalError: (psycopg2.OperationalError) connection to server at "localhost" (::1), port 5432 failed: Connection refused Is the server running on that host and accepting TCP/IP connections? connection to server at "localhost" (127.0.0.1), port 5432 failed: Connection refused Is the server running on that host and accepting TCP/IP connections?

解決辦法:

psql --version查詢到數據庫已有安裝

psql (PostgreSQL) 14.17 (Homebrew)用brew install安裝過了

initdb /usr/local/var/postgres,初始化數據庫

pg_ctl -D /usr/local/var/postgres -s -o "-s" start

在mac上安裝了postgresql。在安裝過程中,我沒有被問到postgresql的密碼。 這很正常,因為brew不需要或創建任何postgres帳戶。PostgreSQL進程在您自己的帳戶下運行。有關信息,請參見brew info postgres的輸出。 要創建新的數據庫帳戶,您可以從自己的操作系統帳戶啟動: /usr/local/bin/createdb postgres提示數據庫已存在(使用以下命令進入到數據庫中) 在psql中: /usr/local/bin/psql -d postgres 然后作為SQL命令:CREATE USER postgres PASSWORD 'yourpassword'; 這應該可以工作,因為brew通常在initdb時間創建:

  • 一個數據庫超級用戶帳戶,與您的操作系統帳戶具有相同的登錄名(在您的情況下似乎是xx

  • 名為postgres的數據庫,可用于記錄管理任務(如創建用戶)的信息。

創建好用戶,還沒完成,還需要有這個數據庫dify

/usr/local/bin/psql -d postgres

進入psql,創建數據庫dify

/usr/local/bin/createdb dify

sqlalchemy.exc.ProgrammingError: (psycopg2.errors.InsufficientPrivilege) permission denied to create extension "uuid-ossp" HINT: Must have CREATE privilege on current database to create this extension.
/usr/local/bin/psql -d postgres  -- 進入psql 
???????ALTER USER postgres CREATEDB; -- 創建數據庫權限 
GRANT CONNECT ON DATABASE dify TO postgres; --連接數據權限 
GRANT CREATE ON DATABASE dify TO postgres; -- 數據庫的創建權限 
CREATE ROLE admin WITH CREATEDB CREATEROLE; -- 角色和庫創建權限 
GRANT admin TO postgres; --授予admin權限給postgres 
\q

再次執行poetry run flask db upgrade終于成功了

踩坑:root未定義

poetry run flask run --host 0.0.0.0 --port=5001 --debug

File "/Users/xx/Desktop/xx/dify/api/extensions/ext_storage.py", line 31, in <lambda>return lambda: OpenDALStorage(dify_config.OPENDAL_SCHEME)^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^File "/Users/xx/Desktop/xx/dify/api/extensions/storage/opendal_storage.py", line 37, in __init__self.op = opendal.Operator(scheme=scheme, **kwargs)  # type: ignore^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
opendal.exceptions.ConfigInvalid: ConfigInvalid (permanent) at  => root is not specified

找到文件:api/extensions/storage/opendal_storage.py

注釋修改代碼行:


# self.op = opendal.Operator(scheme=scheme, **kwargs) type: ignore 
self.op = opendal.Operator(scheme=scheme, 
root='/Users/xx/Desktop/xx/dify/api/storage')

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/74684.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/74684.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/74684.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

質檢LIMS系統在食品生產加工企業的應用 如何保證食品生產企業的安全

在食品生產加工領域&#xff0c;質量安全是貫穿全產業鏈的生命線。隨著《食品安全法》對全過程追溯要求的深化&#xff0c;傳統實驗室管理模式已難以滿足高效、精準的質量管控需求。質檢實驗室信息管理系統&#xff08;LIMS&#xff09;作為數字化升級的核心工具&#xff0c;正…

自動駕駛VLA模型技術解析與模型設計

1.前言 2025年被稱為“VLA上車元年”&#xff0c;以視覺語言動作模型&#xff08;Vision-Language-Action Model, VLA&#xff09;為核心的技術范式正在重塑智能駕駛行業。VLA不僅融合了視覺語言模型&#xff08;VLM&#xff09;的感知能力和端到端模型的決策能力&#xff0c;…

UDP套接字編程(代碼)

什么是socket套接字編程&#xff1f; 通過Ip地址 端口號這種方式定位一臺主機&#xff0c;這樣的方式我們就叫做socket套接字。 Udp Socket 接口介紹 這些案列我們使用的接口基本都是一樣的&#xff0c;所以在這里我先把接口介紹完&#xff0c;具體的細節后面在說明。 創…

汽車行業可信數據空間研究探索

近期&#xff0c;相關老師在新能源汽車國家大數據聯盟微課堂發表了題為“汽車行業可信數據空間研究探索”的演講&#xff0c;主要包括可信數據空間的概念內涵、汽車行業可信數據空間的發展現狀、數據流通場景和技術需求研究、汽車行業可信數據空間的場景建設建議四個方面展開。…

圓弧插補相關算法匯總(C++和ST源代碼)

運動控制需要了解相關的插補概念,在閱讀本篇博客之前需要了解相關的準備知識,常用鏈接如下: SMART PLC直線插補詳解-CSDN博客文章瀏覽閱讀2.1k次,點贊2次,收藏4次。本文介紹了SMART PLC中軸組對象的概念,詳細講解了直線插補的原理和指令使用,包括SMART PLC從V2.7版本開…

Entity Framework框架

深入理解C#中的Entity Framework框架&#xff1a;從理論到實踐 在C#開發中&#xff0c;與數據庫交互是幾乎所有應用程序的核心需求之一。Entity Framework (EF) 作為微軟官方推出的ORM框架&#xff0c;極大地簡化了數據庫操作。本文將帶您深入理解EF框架的核心概念&#xff0c…

C++11QT復習 (五)

文章目錄 **Day6-2 成員訪問運算符重載&#xff08;2025.03.25&#xff09;****1. 復習****2. 成員訪問運算符重載****2.1 箭頭運算符 (->) 重載****(1) 語法** **2.2 解引用運算符 (*) 重載****(1) 語法** **3. 代碼分析****3.1 代碼結構****3.2 代碼解析****(1) Data 類**…

簡歷含金量的描述和注意事項!

背景 最近&#xff0c;在公司負責后端相關面試&#xff0c;簡歷看了不下 50 份&#xff0c;面試 10&#xff0c;純手碼 2000 多字&#xff0c;說說我對簡歷的看法&#xff0c;希望給大家一點啟發。 教育經歷 在眾多求職面試中&#xff0c;我發現多數求職者容易忽視教育背景的…

cellnet框架概述

cellnet框架是一個?高性能、組件化、多協議支持?的開源服務器網絡庫&#xff0c;專注于游戲服務器、分布式的多進程通信等場景的開發。 一、核心特性 ?支持多個主流協議&#xff0c;包括TCP、UDP、HTTP、WebSocket。并且抽象底層協議差異&#xff0c;統一網絡連接管理?。 …

【加密社】如何創建自己的幣圈工具站

需要準備的工作 1.域名 2.服務器 周末的時候主要弄了快訊這方面的代碼 我這里用的是星球日報的api&#xff0c;也可以訂閱他們的rss&#xff0c;這部分在github上是開源的 https://github.com/ODAILY 我這里用的是WordPressonenav主題&#xff0c;然后用小工具在主頁展示&am…

Docker學習筆記(十一)宿主機無法鏈接宿主機問題處理

故障排查優先級排序 服務狀態 → 2. 端口監聽 → 3. 防火墻 → 4. 權限配置 → 5. 網絡路由 &#xff08;按此順序可覆蓋95%的常見問題?15&#xff09; mysql鏡像啟動命令&#xff1a; docker run -p 3306:3306 --restartalways --name mysqlv8 -e MYSQL_ROOT_PASSWORDCd…

力扣:回溯算法

組合I class Solution {List<List<Integer>> result new ArrayList(); // 所有結果集List<Integer> list new ArrayList(); // 當前結果集public List<List<Integer>> combine(int n, int k) {dfs(n, k, 1);return result;}public void dfs(i…

華為HCIE鴻蒙應用開發認證靠譜嗎?

在萬物互聯時代&#xff0c;智能終端設備的多樣性與協同需求催生了操作系統的革新。華為HarmonyOS&#xff08;鴻蒙系統&#xff09;憑借其分布式架構與全場景能力&#xff0c;正成為打破設備邊界、重塑用戶體驗的核心技術底座。HCIE鴻蒙應用開發認證作為華為認證體系的頂級資質…

23種設計模式-原型(Prototype)設計模式

原型設計模式 &#x1f6a9;什么是原型設計模式&#xff1f;&#x1f6a9;原型設計模式的特點&#x1f6a9;原型設計模式的結構&#x1f6a9;原型設計模式的優缺點&#x1f6a9;原型設計模式的Java實現&#x1f6a9;代碼總結&#x1f6a9;總結 &#x1f6a9;什么是原型設計模式…

Oracle-rman restore遭遇RMAN-03002與ORA-19563

文章目錄 在原DB上檢查是否有重復的文件名&#xff1a;查看rman恢復的日志修正重名部分重新執行rman恢復結論&#xff1a; 在 RMAN 恢復過程中&#xff0c;遇到RMAN-03002連同ORA-19563:錯誤。 操作是將 Oracle 10.0.5的數據庫備份從 RMAN備份恢復到另一臺測試主機的同一個目錄…

運維網絡排查工具介紹與使用

作為一名運維工程師&#xff0c;日常工作中最令人頭疼的莫過于各種網絡故障。在過去一年半的運維生涯中&#xff0c;我積累了豐富的網絡故障排查經驗&#xff0c;今天就來和大家分享一下如何運用抓包工具&#xff08;Wireshark、tcpdump&#xff09;和網絡排查工具&#xff08;…

解決vscode終端和本地終端python版本不一致的問題

&#x1f33f; 問題描述 本地終端&#xff1a; vscode終端&#xff1a; 別被這個給騙了&#xff0c;繼續往下看&#xff1a; 難怪我導入一些包的時候老提示找不到&#xff0c;在本地終端就不會這樣&#xff0c;于是我嚴重懷疑vscode中的python版本和終端不一樣&#xff0c…

Sublime全局搜索快捷鍵Ctrl+Shift+F不能使用解決

問題描述&#xff1a; 在安裝好Sublime后&#xff0c;我們使用快捷鍵進行全局搜索&#xff0c;發現沒有反應&#xff0c;但是中文輸入變成了繁體。 解決方案&#xff1a; 如截圖&#xff0c;在關閉簡繁切換的快捷鍵或者換成其他的就行

海康HTTP監聽報警事件數據

http監聽接收報警事件數據 海康獲取設備報警事件數據兩種方式&#xff1a; 1、sdk 布防監聽報警事件數據,服務端布防。&#xff08;前面文章有示例&#xff09; 2、http監聽接收報警事件數據&#xff0c;設備直接推送。 http監聽接收報警事件數據&#xff0c;服務端可以使用n…

Python----計算機視覺處理(Opencv:圖像邊緣檢測:非極大值抑制,雙閾值篩選)

一、 高斯濾波 邊緣檢測本身屬于銳化操作&#xff0c;對噪點比較敏感&#xff0c;所以需要進行平滑處理。這里使用的是一個5*5的高斯 核對圖像進行消除噪聲。 二、計算圖像的梯度和方向 三、非極大值抑制 在得到每個邊緣的方向之后&#xff0c;其實把它們連起來邊緣檢測就算完了…