1 文件目錄指令 1 pwd 顯示當前目錄的絕對路徑。 說明當前位置在/home/sora 2 cd 切換到指定目錄。 cd ~ 切換到當前用戶的家目錄:如果當前用戶為root,會切換到/root/,如果當前用戶為普通用戶名字叫做A,會切換到/home/A/。 cd .. 切換到上一級目錄 3 mk ...
因為Linux發行版本的問題折騰了好久,儘量使用LTS的版本。其他版本有時候缺的東西太多了,對新手相當不友好。
大概花了幾天實在沒招了,下了個LTS的版本,再裝時正常了。按照官方文檔都可以搞定了。
使用這個版本的ubuntu-22.04.2-desktop-amd64.iso的,官網上下的,用虛擬機弄個上裝了下,檢查下有沒有聯網。
ping www.baidu.com
- 首先切root上,不知道前幾個版本時不是也是這個原因,反正到處缺包報錯。最後上這個直接切root。
#用戶叫xman 在 xman-virtual-machine的機子上登錄 xman@xman-virtual-machine:~$ su - Password: root@xman-virtual-machine:~#
輸入 su - 會讓你輸入密碼,輸入當前賬號的登錄密碼。切成root用戶。安裝許可權最大,但是docker群組有些操作不了,文件夾也訪問不全,
還要授權亂七八糟。
- 然後安裝,找到官網 Install Docker Engine on Ubuntu
#清空歷史版本 sudo apt-get remove docker docker-engine docker.io containerd runc #更新下包管理器 sudo apt-get update #允許https類型的通過 sudo apt-get install \ ca-certificates \ curl \ gnupg \ lsb-release #Docker’s official GPG key sudo mkdir -m 0755 -p /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg #設定存儲庫 echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \ $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null #更新包管理器 sudo apt-get update #如果更新出錯GPGkey有誤 sudo chmod a+r /etc/apt/keyrings/docker.gpg sudo apt-get update #安裝docker sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin #用預設的容器檢查下是否安裝成功 sudo docker run hello-world
以上都完了以後就代表安裝成功,真真的門檻安裝都吃力。
- 查一下本機對外提供服務的IP,使用這個建立個網橋
ip address
如果聯網了,你大概能看到你的IP,作為對外通訊的IP
然後建立個網橋,作為容器和本機的通道,這樣容器通過這個橋使用本機東西對外提供服務
#查看網橋的內容,一般有幾個 docker network ls #清空沒用的網路 docker network prune #如果一個網橋被使用中你刪不掉需要先關掉容器,刪除容器,然後刪除 docker stop mycontainer1 docker rm mycontainer1 docker network prune # 清除不用的網橋後大體乾凈了,就做個自己用本機對外提供服務的IP做 docker network create \ -o "com.docker.network.bridge.host_binding_ipv4"="192.168.139.129" \ br0
#檢查下狀態有沒有問題
docker net ls
- 下載MySQL並安裝
#查一下現有的鏡像 docker images #如果下來了直接裝,沒有下來就下一下,不寫版本預設是last的 docker pull mysql #然後安裝 docker run -di --privileged=true -p 3306:3306 --network=br0 -v /home/mysql/log:/var/log/mysql -v /home/mysql/data:/var/lib/mysql -v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf -v /home/mysql/mysql-files:/var/lib/mysql-files -e MYSQL_ROOT_PASSWORD=123456 --name my mysql
-
-di d 後臺運行,有守護進程處理 i 可以交互 這個弄了以後就不用手動啟動了
-
--privileged=true 提升許可權,防止MySQL的有些目錄沒許可權訪問
-
-p 3306:3306 埠映射 主埠:容器埠 容器的口接到主機上對外提供服務
-
--network=br0 使用網橋 br0創建此容器,並對外提供服務
-
-v /home/mysql/log:/var/log/mysql
-
-v /home/mysql/data:/var/lib/mysql
-
-v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf
-
-v /home/mysql/mysql-files:/var/lib/mysql-files
-
主機目錄:容器目錄,把容器的數據和配置文件掛載到主機上防止丟失和配置同步,這個是以前的如果需要改遠程訪問的改 my.cnf文件
-
-e MYSQL_ROOT_PASSWORD=123456 配置登錄資料庫root用戶的密碼是123456,到時候進容器可以用這個進資料庫
-
--name my mysql 容器名稱 容器創建依據的鏡像名稱
- 先進去看看容器,並且切到MySQL中看看允許遠程訪問不
#交互進去my容器中 docker exec -it my /bin/bash #進入MySQL看看 mysql -uroot -p123456 #切到管理資料庫 use mysql; #查看下是否允許遠程訪問 select user,host from user; #如果不允許改下 update user set host ='%' where user ='root';
#刷新許可權
flush privileges;
#如果不想用這個自己建個用戶
CREATE USER 'username'@‘%' IDENTIFIED BY '123';
#然後授權
grant all privileges on *.* to 'username'@'%' ;
#同樣刷新一下
flush privileges; #退出MySQL exit; #退出容器 exit
- 遠程連接一下看看
在遠程機器上輸入IP連接一下貌似可以
至此搞完。
另外記錄下vi的作業。linux的編輯器對windows轉過來的很不友好。
#可以打開一個這個位置的cnf的文件 vi /home/bin/conf.cnf #預設是命令模式,不支持輸入字元,輸入的都是命令 可以使用滾輪HJKL來移動到你想要的行列home|end也可以 移動了以後摁i以後進入編輯模式 shift+字元好像才可以輸入想要的字元,一不註意就跑回命令模式了。 並且上下左右箭頭是ABCD字元, dd可以刪除一行 delete可以刪除一個字元 u是撤銷更改 連按兩次Esc可以切換到命令模式 想保存摁: 然後q!直接退出忽略更改 wq保存並退出 搞這玩意的時候最好確定你有許可權動這個文件,要不費勁弄完,就笑了。
一些想法,一些隨筆,零零碎碎整理下思路。