Docker常用軟體安裝

来源:https://www.cnblogs.com/zhuxiaoyi412826/archive/2023/03/27/17261792.html
-Advertisement-
Play Games

jdk dockere pull openjdk:11 docker run -d -t --name java-11 openjdk:11 MySQL 可以從docker hup中查找自己想要安裝的版本 docker pull mysql:5.7 拉取鏡像 創建容器 # 在/root目錄下創建my ...


jdk

dockere pull openjdk:11
docker run -d -t --name java-11 openjdk:11 

MySQL

可以從docker hup中查找自己想要安裝的版本
docker pull mysql:5.7  拉取鏡像 
創建容器 
# 在/root目錄下創建mysql目錄用於存儲mysql數據信息
mkdir /root/mysql    cd /root/mysql

docker run -id \
-p 3307:3306 \
--name=ydl_mysql \
-v /root/mysql/conf:/etc/mysql/conf.d \
-v /root/mysql/logs:/logs \
-v /root/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7

進入容器
docker exec -it ydl_mysql /bin/bash
進入MySQL  
mysql -uroot -p 
123456
遠程連接MySQL

exit退出 
如果遠程連接有問題 
https://www.cnblogs.com/zhangxiaoxia/p/13043508.html
修改MySQL的字元編碼
修改my.cnf 文件
cd /mydata/mysql/conf
vim my.conf 

[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
[mysqld]
init_connect='SET collation_connection = utf8mb4_bin'
init_connect='SET NAMES utf8mb4'
character_set_server = utf8mb4
collation_server = utf8mb4_bin
skip-character-set-client-handshake
skip-name-resolve

  • -p 3307:3306:將容器的 3306 埠映射到宿主機的 3307 埠。
  • -v $PWD/conf:/etc/mysql/conf.d:將主機當前目錄下的 conf/my.cnf 掛載到容器的 /etc/mysql/my.cnf。配置目錄
  • -v $PWD/logs:/logs:將主機當前目錄下的 logs 目錄掛載到容器的 /logs。日誌目錄
  • -v $PWD/data:/var/lib/mysql :將主機當前目錄下的data目錄掛載到容器的 /var/lib/mysql 。數據目錄
  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用戶的密碼。

MySQL5.7

穀粒商城

1 docker pull mysql:5.7 下載docker鏡像

2 運行MySQL 容器

docker run -p 3306:3306 --name mysql \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7
參數說明
-p 3306:3306:將容器的 3306 埠映射到主機的 3306 埠
-v /mydata/mysql/conf:/etc/mysql:將配置文件夾掛載到主機
-v /mydata/mysql/log:/var/log/mysql:將日誌文件夾掛載到主機
-v /mydata/mysql/data:/var/lib/mysql/:將配置文件夾掛載到主機
-e MYSQL_ROOT_PASSWORD=root:初始化 root 用戶的密碼為root

3 SQLyong進行遠程連接

grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
flush privileges 刷新許可權 

4 修改配置文件

cd /mydata/mysql/conf
vim my.conf 
[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
init_connect='SET collation_connection = utf8mb4_bin'
init_connect='SET NAMES utf8mb4'
character_set_server = utf8mb4
collation_server = utf8mb4_bin
skip-character-set-client-handshake
skip-name-resolve

這個字元編碼不要設置為utf8 MySQL容器會啟動不起來 報錯
Error response from daemon: Container 7819b1b3c5a7f3efe4ec7e8bab59e80ad13f10a57b7b5484f664b205d3c1ce0d is not running
這個是錯誤示範
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
init_connect='SET collation_connection = utf8_unicode_ci' init_connect='SET NAMES utf8' character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve
[mysqld]
skip-name-resolve


Tomcat

官方的webapps是沒有文件是需要自己弄得

docker search tomcat  
docker pull tomcat
 創建埠映射
# 在/root目錄下創建tomcat目錄用於存儲tomcat數據信息
mkdir /root/tomcat
cd /root/tomcat
docker run -id --name=ydl_tomcat \
-p 8081:8080 \
-v /root/tomcat:/usr/local/tomcat/webapps \
tomcat 
外部訪問
http://宿主機ip:8081/

Nginx

docker search nginx
docker pull nginx
埠映射
# 在/root目錄下創建nginx目錄用於存儲nginx數據信息
mkdir /root/nginx
cd /root/nginx
mkdir conf
cd conf
文件配置
# 在~/nginx/conf/下創建nginx.conf文件,粘貼下麵內容
vim nginx.conf


user  nginx;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


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;

    include /etc/nginx/conf.d/*.conf;
}
docker run -id --name=ydl_nginx \
-p 80:80 \
-v /root/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /root/nginx/logs:/var/log/nginx \
-v /root/nginx/html:/usr/share/nginx/html \
nginx

外部機器訪問

Redis

docker search redis
docker pull redis:5.0
docker run -id --name=ydl_redis -p 6380:6379 redis:5.0
外部連接

穀粒商城

1下載redis
docker pull redis
如果不先創建這個conf文件 等會目錄進行掛載的時候會吧redis.conf文件當成一個目錄
mkdir -p /mydata/redis/conf && touch /mydata/redis/conf/redis.conf
2 啟動容器 目錄掛載
docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf
啟動redis客戶端 
3  docker exec -it redis redis-cli
4  在redis.conf 中寫入
appendonly yes  開啟AOF 持久化

需要配置密碼 如果不陪著密碼很危險

1在創建容器的時候配置密碼
--requirepass
2 創建容器之後配置密碼
docker exec -it 容器ID bash
進入redis目錄
cd /usr/local/bin
運行命令:
redis-cli
設置redis密碼
config set requirepass 密碼
如出現:(error) NOAUTH Authentication required
這是因為redis設置了密碼,我們需要使用密碼來進行驗證之後再來對redis客戶端進行操作,否則我們沒有操作redis緩存資料庫的許可權。
需要用  auth 密碼

如果使用redis 連接 Another Redis Desktop Manager

報錯 Redis Client On Error: ReplyError: WRONGPASS invalid username-password pair or user is disabled. Con 就不要設置用戶名

部署ELK

elasticsearch安裝

1 下載鏡像

docker pull elasticsearch:7.4.2

2 創建和容器內配置文件映射的文件

mkdir -p /mydata/elasticsearch/config 
mkdir -p /mydata/elasticsearch/data

3 添加配置文件

echo "http.host: 0.0.0.0" >> /mydata/elasticsearch/config/elasticsearch.yml

4 添加許可權

chmod -R 777 /mydata/elasticsearch/

5 運行容器

 docker run --name elasticsearch -p 9200:9200 -p 9300:9300 \
 -e "discovery.type=single-node" \
 -e ES_JAVA_OPTS="-Xms256m -Xmx512m" \
 -v /mydata/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
 -v /mydata/elasticsearch/data:/usr/share/elasticsearch/data \
 -v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
 -d elasticsearch:7.4.2

kiban

docker pull kibana:7.4.2
docker run --name kibana \
-e ELASTICSEARCH_HOSTS=http://120.78.150.188:9200 -p 5601:5601 \
-d kibana:7.4.2

但是還要進行目錄掛載修改 yml文件 設置中文

IK分詞器

Ik分詞器版本要和ES和Kibana版本保持一致 不然可能啟動不了docker

進入容器

此命令需要在容器中運行

elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.8.0/elasticsearch-analysis-ik-7.8.0.zip

退出容器,重啟容器

exit
docker restart es7.8

nacos

如果用docker安裝naocs如果是 2版本可能會啟動不了

 docker pull nacos/nacos-server:1.3.1
docker  run \
--name nacos -d \
-p 8848:8848 \
--privileged=true \
--restart=always \
-e JVM_XMS=256m \
-e JVM_XMX=256m \
-e MODE=standalone \
-e PREFER_HOST_MODE=hostname \
nacos/nacos-server:1.3.1

訪問測試 http://43.138.137.168:8848/nacos

MQ

docker run \
 -e RABBITMQ_DEFAULT_USER=zhuxiaoyi \
 -e RABBITMQ_DEFAULT_PASS=412826zxyZXY \
 --name rabbitmq \
 --hostname mq1 \
 -p 15672:15672 \
 -p 5672:5672 \
 -d \
 rabbitmq:3-management

Nginx

mkdir /root/docker/nginx
mkdir /root/docker/nginx/conf

由於我們現在沒有配置文件,也不知道配置什麼。可以先啟動一個nginx,講他的配置文件拷貝出來

再作為映射,啟動真正的nginx

docker pull nginx:1.17.4
docker run --name some-nginx -d nginx:1.17.4
docker container cp some-nginx:/etc/nginx /root/docker/nginx/conf

然後就可以刪除這個容器了

docker docker rm -f some-nginx

在重新啟動nginx

docker run --name nginx -p 80:80 \
        -v /root/docker/nginx/conf:/etc/nginx \
        -v /root/docker/nginx/html:/usr/share/nginx/html \
        -d nginx:1.17.4

FTP伺服器

1 需要賬號和密碼

docker run -v /data/dav:/usr/local/nginx/html  -d -p 88:80 lutixiaya/nwebdav:latest
chmod o+w /data/dav

ip+埠訪問測試 需要輸入賬號和密碼

使用winscp 進行連接

1、點擊新建站點
2、選擇協議
3、輸入伺服器ip
4、輸入埠
5、輸入用戶名,預設用戶:admin
6、輸入密碼,預設密碼:bash.lutixia.cn
7、登錄

https://zhuanlan.zhihu.com/p/573721115 參考鏈接

2 無需賬號和密碼

在同一個文件目錄下準備好這個三個文件

start-nginx.sh
#!/bin/bash
mkdir data
docker stop nginx_file_server
docker rm nginx_file_server

docker run -d -p 8081:8080\
        --name nginx_file_server \
        -v $(pwd)/data:/data \
        -v $(pwd)/nginx.conf:/etc/nginx/nginx.conf \
        -v $(pwd)/default.conf:/etc/nginx/conf.d/default.conf \
        nginx:stable-alpine
nginx.conf

nginx.conf

user  root;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

events {
    worker_connections  1024;
}

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;
    include /etc/nginx/conf.d/*.conf;
}
default.conf

default.conf

server {
    listen 8080; #埠
    server_name localhost; #服務名

    # for SSL listen port only
    #ssl_certificate                /etc/nginx/conf.d/server.pem;
    #ssl_certificate_key            /etc/nginx/conf.d/server-key.pem;
    #ssl_protocols                  TLSv1.2;
    #ssl_prefer_server_ciphers      on;
    #ssl_session_timeout            5m;
    #ssl_ciphers                    ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    #underscores_in_headers         on;

    charset utf-8; # 避免中文亂碼
    root /data; #顯示的根索引目錄,註意這裡要改成你自己的,目錄要存在
    location / {
        autoindex on;             #開啟索引功能
        autoindex_exact_size off; # 關閉計算文件確切大小(單位bytes),只顯示大概大小(單位kb、mb、gb)
        autoindex_localtime on;   # 顯示本機時間而非 GMT 時間
    }
}

chmod +x start-nginx.sh && ./start-nginx.sh`

測試一下:

echo file_server > data/file1.txt

打開瀏覽器 http://127.0.0.1:8081/

img

DockerCompose

sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose 
docker-compose --version

安裝GitLab

1 下載鏡像

docker pull twang2218/gitlab-ce-zh

2 啟動容器

docker run -d -p 8443:443 -p 8090:80 -p 8022:22 --restart always --name gitlab -v /usr/local/gitlab/etc:/etc/gitlab -v /usr/local/gitlab/log:/var/log/gitlab -v /usr/local/gitlab/data:/var/opt/gitlab --privileged=true twang2218/gitlab-ce-zh

3 進入容器修改配置文件

由於進行了目錄映射 也可以不在容器內部進行修改

docker exec -it gitlab bash
cd /etc/gitlab 
vim /etc/gitlab/gitlab.yml

4 修改配置文件

搜索URL

external_url 'http://gitlab.example.com'

把url換成自己的

external_url 'http://116.205.133.97/'

nginx['listen_port'] = nil

nginx['listen_port'] = 82 這個是註釋掉的

5 重啟服務

這是在容器內部重啟服務

gitlab-ctl restart

gitlab是有很多組件組成的只有這些組件都運行成功了,才啟動成功。

6 訪問測試

http://120.78.214.226:8090

第一次登錄預設是root用戶 密碼自己設定 不要低於8位

安裝Jenkins

1 下載鏡像

docker pull jenkinsci/blueocean    中文版本

2 創建目錄

# mkdir /home/jenkins_home
# chown -R 1000:1000 /home/jenkins_home/
# chown -R 1000:1000 /usr/local/src/jdk/jdk1.8/
# chown -R 1000:1000 /opt/apache-maven-3.5.0/

3 運行容器

docker run \
-d \
--name jenkins \
-p 9999:8080 \
-p 8888:8888 \
-p 50000:50000 \
-v /usr/local/src/jdk/jdk1.8:/usr/local/src/jdk/jdk1.8 \
-v /opt/apache-maven-3.5.0:/opt/apache-maven-3.5.0 \
-v/home/jenkins_home:/var/jenkins_home \
jenkins/jenkins:2.222.3-centos

4 查看密碼

docker exec -it jenkins bash
cat /var/jenkins_home/secrets/initialAdminPassword 

b0468f2eb870422abf509fe59f74e003

5 訪問測試

http://120.78.214.226:9999/

6 進行漢化

在安裝插件頁面輸入 chinese

7 替換插件下載地址

https://blog.csdn.net/weixin_45878889/article/details/123867587 

安裝SonarQube

https://blog.csdn.net/OfficerGoodbody/article/details/126662724

新版SonarQube不支持MySQL

1 下載postgres鏡像

docker pull postgres

2 創建文件

mkdir -p /opt/postgres/postgresql
mkdir -p /opt/postgres/data

3 創建網路

docker network create sonarqube

4 運行postgres 容器

docker run --name postgres -d -p 5432:5432 --net sonarqube \
-v /opt/postgres/postgresql:/var/lib/postgresql \
-v /opt/postgres/data:/var/lib/postgresql/data \
-v /etc/localtime:/etc/localtime:ro \
-e POSTGRES_USER=sonar \
-e POSTGRES_PASSWORD=sonar \
-e POSTGRES_DB=sonar \
-e TZ=Asia/Shanghai \
--restart always \
--privileged=true \
--network-alias postgres \
postgres:latest

5 安裝 sonarQube

docker pull sonarqube

6 準備文件夾

mkdir -p /opt/sonarqube

echo "vm.max_map_count=262144" > /etc/sysctl.conf
sysctl -p

7 先運行一下拷貝文件

docker run -d --name sonarqube sonarqube
docker cp sonarqube:/opt/sonarqube/conf /opt/sonarqube
docker cp sonarqube:/opt/sonarqube/data /opt/sonarqube
docker cp sonarqube:/opt/sonarqube/logs /opt/sonarqube
docker cp sonarqube:/opt/sonarqube/extensions /opt/sonarqube

8 刪除容器

docker stop  sonarqube
docker rm  sonarqube

9 添加許可權

chmod -R 777 /opt/sonarqube/

10 修改配置文件

vim /opt/sonarqube/conf/ sonar.properties
修改賬號和密碼
sonar.jdbc.username=sonar
sonar.jdbc.password=sonar
sonar.jdbc.url=jdbc:postgresql://postgres:5432/sonar

11 運行容器

docker run -d --name sonarqube -p 9090:9000 \
 -e ALLOW_EMPTY_PASSWORD=yes \
 -e SONARQUBE_DATABASE_USER=sonar \
 -e SONARQUBE_DATABASE_NAME=sonar \
 -e SONARQUBE_DATABASE_PASSWORD=sonar \
 -e SONARQUBE_JDBC_URL="jdbc:postgresql://postgres:5432/sonar" \
 --net sonarqube \
 --privileged=true \
 --restart always \
 -v /opt/sonarqube/logs:/opt/sonarqube/logs \
 -v /opt/sonarqube/conf:/opt/sonarqube/conf \
 -v /opt/sonarqube/data:/opt/sonarqube/data \
 -v /opt/sonarqube/extensions:/opt/sonarqube/extensions\
 sonarqube

12測試訪問

瀏覽器輸入http://ip:9090,開始初始化資料庫初始化成功後進入登錄界面,賬號:admin 密碼:admin

輕量級容器監控

portanier

下載 docker pull lihaixin/portainer

docker run -d -p 9000:9000 --restart=always \
-v /var/run/docker.sock:/var/run/docker.sock \
--name portainer lihaixin/portainer

訪問測試 http://43.138.137.168:9000/#/home

重量級 容器監控

docker-compose.yml配置

version: '3.1'
volumes:
  grafana_data: {} 
services:
 influxdb:
  image: tutum/influxdb:0.9
  restart: always
  environment:
    - PRE_CREATE_DB=cadvisor
  ports:
    - "8083:8083"
    - "8086:8086"
  volumes:
    - ./data/influxdb:/data
 
 cadvisor:
  image: google/cadvisor
  links:
    - influxdb:influxsrv
  command:
   -storage_driver=influxdb - storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
  restart: always
  ports:
    - "8080:8080"
  volumes:
    - /:/rootfs:ro
    - /var/run:/var/run:rw
    - /sys:/sys:ro
    - /var/lib/docker/:/var/lib/docker:ro
 
 grafana:
  user: "104"
  image: grafana/grafana
  user: "104"
  restart: always
  links:
    - influxdb:influxsrv
  ports:
    - "3000:3000"
  volumes:
    - grafana_data:/var/lib/grafana
  environment:
    - HTTP_USER=admin
    - HTTP_PASS=admin
    - INFLUXDB_HOST=influxsrv
    - INFLUXDB_PORT=8086
    - INFLUXDB_NAME=cadvisor
    - INFLUXDB_USER=root
    - INFLUXDB_PASS=root

docker-compose up -d


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Qt 源碼分析之moveToThread 這一次,我們來看Qt中關於將一個QObject對象移動至一個線程的函數moveToThread Qt使用線程的基本方法 首先,我們簡單的介紹一下在Qt中使用多線程的幾種方法: 重寫QThread的run函數,將要在多線程執行的任務放到run函數里 /*myt ...
  • Object類的使用 Object類 Object類中的方法可以在網上搜索得到 Object類是所有java類的父類 如果類在聲明中未使用extends關鍵字指明其父類,則預設父類為java.lang.Object類 Object類中的功能(屬性、方法)具有通用性。 屬性:無 方法:equals() ...
  • 首先任何的商業邏輯,光流量增長,沒法變現是沒用的。 就像博客群發提效工具,得有對應的用戶,更得有對應付費用戶群體的畫像。剩下的就是靠增長,被動讓他們找到你的產品,用產品解決他們痛點,他們自然而然會付費。 下麵大致分享下從三個方向分享下: 用戶痛點 -> 真正的付費用戶群體 產品價值 PLG 增長 一 ...
  • spring源碼環境搭建 組件 版本 jdk 1.8.0_192 spring-framework 5.3.x gradle 7.5.1 idea 2022.3.3 aspectJ 1.9 可根據spring-framwork項目說明靈活選擇 一、拉取spring-framework項目 1、spr ...
  • 向下轉型的使用 Java的多態性: 父類指向子類的聲明 Animal animal = new Dog()//Dog()重寫了父類Animal 有了對象的多態性以後,記憶體實際上載入的是==子類==的屬性和方法,但是由於變數聲明為==父類類型==,導致編譯時只能調用父類的屬性和方法,子類特有的屬性方法 ...
  • 紙殼CMS支持將評論、留言、表單提交、訂閱等通知,通過WebHook發送到第三方平臺,比如釘釘。 創建釘釘WebHook 需要在釘釘群中創建自定義機器人,具體方法可以參考釘釘的官方文檔: 自定義機器人接入 需要註意的是,在安全設置中不要使用加簽,使用自定義關鍵字即可。在發送的消息中,只要包含這個關鍵 ...
  • 在實際工作中,經常會有一些需要定時操作的業務,如:定時發郵件,定時統計信息等內容,那麼如何實現才能使得我們的項目整齊劃一呢?本文通過一些簡單的小例子,簡述在.Net6+Quartz實現定時任務的一些基本操作,及相關知識介紹,僅供學習分享使用,如有不足之處,還請指正。 ...
  • @ 先看一下導出的整體效果(如下圖),其中標註的區域都是通過後臺動態生成的: 一、先在Word中建立好表格模板 1.1、參數創建方法(Word和WPS) 1.1.1、Office中Word域的創建 1.1.1.1、選中指定的單元格 -> 點擊頭部工具欄中的”插入“ -> 選擇 ”文檔部件“ -> 選 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...