銀河麒麟部署mysql8.0并連接應用

?客戶需在國產化銀河麒麟系統中部署軟件應用,使用mysql8.0數據庫。機器放置了兩三年,里面命令工具和依賴都不太全。而且客戶環境不聯網,只能采用離線部署的方式。部署過程中踩了很多坑,也用到很多資源,記錄一下。

過程概述

最開始從mysql官網下載了arm版本的安裝包,但是服務器缺少的依賴太多了。我們連續裝了兩個依賴之后發現這是個無底洞……遂更換為docker拉包的方式部署。

資源準備

1、docker安裝包,準備docker-20.10.9.tgz文件包,適用于arm架構的相近版本都可以。可以從本文頂部鏈接下載,也可以自行準備。

2、mysql鏡像包,從網上下載一個同樣適用于arm架構的mysql8.tar包。

安裝步驟

部署docker

1、解壓安裝包:

tar -xvf docker-20.10.9.tgz   #(改成自己的版本)

2、將解壓出來的docker文件內容移動到 /usr/bin/ 目錄下

  mv docker/* /usr/bin/ 

3、將docker注冊為service服務

vi /etc/systemd/system/docker.service

編輯docker.service文件的內容:

[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target

4、啟動docker

chmod +x /etc/systemd/system/docker.service #設置權限
systemctl daemon-reload
systemctl start docker            #啟動Docker

如果需要設置自啟或查看docker狀態或日志,可參考以下命令:

systemctl enable docker.service   #設置開機自啟
systemctl status docker  #查看Docker狀態
docker -v                #查看Docker版本
journalctl -u docker.service #查看詳細日志

上傳mysql鏡像

1、將mysql8.tar上傳到服務器,并拉取鏡像

docker load -i 路徑/mysql8.tar #改成存放路徑

2、修改my.cnf文件

vi /etc/my.cnf

內容按需配置

[mysqld]
datadir=數據目錄/data
port=3306
innodb_buffer_pool_size=2047M
character-set-server=utf8
max_length_for_sort_data = 8388608
join_buffer_size=1048576
sort_buffer_size =3145728
read_rnd_buffer_size = 838860800
#default-storage-engine=MyISAM
default-storage-engine=Innodb
max_allowed_packet=1073741824
wait_timeout=2147483
interactive_timeout=2880000
innodb_file_per_table=1
innodb_file_format=Barracuda
innodb_strict_mode = 0
[client]
port=3306

3、配置參數并啟動容器,主要修改配置文件路徑映射、端口映射,主機的路徑、端口在冒號前,容器的路徑、端口在冒號后。

docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=123456 -v /path/to/my.cnf:/etc/mysql/my.cnf -v /path/to/data:/var/lib/mysql -p 3306:3306 -d 鏡像id  #自行修改

4、查看mysql是否啟動成功:
進入容器,使用mysql -uroot -p密碼,看看是否輸出連接成功信息。

5、初始化數據庫,使應用可以連接數據庫而非本地連接,請參考此文章后半部分初始化數據庫部分:在同一臺主機上運行MySQL和MariaDB

配置宿主機上應用的JDBC

jdbc:mysql://localhost:3306/數據庫名?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&allowPublicKeyRetrieval=true

這里的ip就是localhost,因為容器和宿主機是一個網,不用修改。
啟動應用,連接成功。

中途遇到的問題

1、權限不夠
我使用非root用戶登錄的,su -root登錄不成功。最后使用

sudo su

輸入當前用戶密碼后切換到了root用戶。

2、運行權限不夠

./startup.sh(程序)

運行應用程序過程中總是報permission denied,最后使用

sudo bash startup(程序名)

成功運行。

3、使用rpm提示功能不存在
銀河麒麟系統和ubuntu比較接近,可使用

dpkg -l | grep mysql

查詢系統中是否之前安裝過mysql

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

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

相關文章

GitAgent-面壁智能聯合清華大學發布的大模型智能體應用框架

本文轉載自:https://www.hello123.com/gitagent ** 一、🔍 GitAgent 框架:大模型智能體的工具箱革命 GitAgent 是由面壁智能與清華大學自然語言處理實驗室聯合研發的創新型框架,旨在解決大模型智能體在復雜任務中的工具擴展瓶頸…

靈碼產品演示:Maven 示例工程生成

作者:輕眉 演示主題:由 AI 自動生成 0 到 1 的電商訂單 Java 項目 演示目的 面向 Java 零基礎的用戶,通過靈碼的產品能力(如提示詞、編碼智能體、項目 Rules 和 SQLite MCP 服務、單元測試)自動生成 0 到 1 的電商訂單…

AI編程從0-1開發一個小程序

小伙伴們,今天我們利用AI實現從0到1開發一個小程序!需求交給AI: 我們只要說出自己的開發思路,具體需求交給AI完成!輸入提示詞:個人開發的小程序 能開發哪些好備案,用戶喜歡使用的 AI給出…

DDoS高防IP是什么? DDoS攻擊會暴露IP嗎?

DDoS高防IP是什么?高防IP是指一種網絡安全服務,主要用于防御DDoS攻擊。隨著技術的發展,黑客進行網絡攻擊的強度也在加大,所以我們要做好網絡防護,及時預防DDoS攻擊。DDoS高防IP是什么?DDoS高防IP是指基于IP…

k8s事件驅動運維利器 shell operator

Shell-Operator 概述 Shell-Operator 是 Kubernetes 的一個工具,用于通過 shell 腳本擴展集群功能。它允許用戶編寫簡單的腳本(Bash、Python 等)來響應 Kubernetes 事件(如資源變更、定時任務),無需編譯復…

(二)文件管理-文件權限-chmod命令的使用

文章目錄1. 命令格式2. 基本用法2.1 符號模式2.2 八進制數字模式3. 高級用法3.1 遞歸操作3.2 參考權限3.3 特殊權限位(Setuid, Setgid, Sticky Bit)3.4 X 特殊執行權限4. 注意事項4.1權限與所有權4.2 Root 權限4.3 安全風險4.4 -R 的風險4.5 目錄的執行權限1. 命令格式 chmod …

醫院預約掛號腳本

醫院預約掛號腳本 功能介紹 本腳本是一個用 Python 編寫的醫院預約掛號程序,支持以下功能: 自動預約:通過api交互選擇醫院、科室、醫生和時間段。自動監控:持續檢查指定醫生的號源狀態,發現可預約時段時自動嘗試預約。…

.NET駕馭Word之力:理解Word對象模型核心 (Application, Document, Range)

在使用MudTools.OfficeInterop.Word庫進行Word文檔自動化處理時,深入理解Word對象模型的核心組件是至關重要的。Word對象模型提供了一套層次化的結構,使開發者能夠通過編程方式控制Word應用程序、文檔以及文檔內容。本章將詳細介紹Word對象模型中最核心的…

Kotlin在醫療大健康域的應用實例探究與編程剖析(上)

一、引言 1.1 研究背景與意義 在當今數字化時代,醫療行業正經歷著深刻的變革。隨著信息技術的飛速發展,尤其是人工智能、大數據、物聯網等新興技術的廣泛應用,醫療行業數字化轉型已成為必然趨勢。這種轉型旨在提升醫療服務的效率和質量,優化醫療資源配置,為患者提供更加…

AI智能體的應用前景

AI智能體的應用前景正從技術探索邁向規模化落地的關鍵階段,其發展動力源于大模型能力的突破、行業需求的深化以及商業化模式的創新。以下是基于最新技術動態和行業實踐的深度解析: 一、技術突破:從「有腦無手」到「知行合一」 大模型的進化顯著提升了智能體的多模態交互與…

高系分四:網絡分布式

目錄一、我的導圖和思考二、大模型對我導圖的評價優點可優化之處三、大模型對這章節的建議一、網絡知識范疇(一)網絡基礎理論(二)局域網與廣域網(三)網絡安全(四)網絡性能優化&#…

Day24_【深度學習(1)—概念】

一、AI、ML、DL基本關系 機器學習是實現人工智能的途徑,深度學習是機器學習的一種方法。人工智能 (AI)↓ 機器學習 (ML) —— 讓機器從數據中學習規律↓ 深度學習 (DL) —— 使用深層神經網絡的機器學習方法二、深度學習與機器學習概念深度學習(Deep Lea…

VTK基礎(01):VTK中的基本概念

VTK中的基本概念 1.三維場景中的基本要素 三維場景的基本要素包含:燈光、相機、顏色和紋理映射 (1)燈光vtkLight 光的本質是特定頻段的電磁波,所以燈光的本質是特定頻段(可見光頻段)的電磁波發射器;依據發射可見光頻段…

LeetCode 2348.全0子數組的數目

給你一個整數數組 nums ,返回全部為 0 的 子數組 數目。 子數組 是一個數組中一段連續非空元素組成的序列。 示例 1: 輸入:nums [1,3,0,0,2,0,0,4] 輸出:6 解釋: 子數組 [0] 出現了 4 次。 子數組 [0,0] 出現了 2 次。…

【wpf】從 DataContext 到依賴屬性:WPF 自定義控件 ImageView 的優化之路

從 DataContext 到依賴屬性:WPF 自定義控件 ImageView 的優化之路 最近我在做一個 WPF 項目,需要封裝一個 ImageView 控件,用來顯示圖像并處理鼠標交互。 在實際開發中,我遇到了一系列和 數據綁定 有關的問題: 控件需要…

人力資源管理的思維方式學習筆記2

戰略人力資源管理的思維方式——北京師范大學政府管理學院——王建民 教授3.1.理念:人力資源是第一戰略資源 我們先來了解海爾集團公司實施發展戰略的情況。海爾集團創立于1984年,根據官方網站的介紹,目前是一家全球領先的美好生活解決方案服…

汽車網絡安全 CyberSecurity ISO/SAE 21434 測試之一

一、什么是網絡安全? 在智能網聯和自動駕駛技術進入汽車行業之前,功能安全 一直是汽車開發的核心。 簡單來說,功能安全的目標是確保車輛的系統在出現故障時,不會對人、環境或者設備造成危害。比如,剎車失靈了&#xff…

力扣(LeetCode) ——217. 存在重復元素(C++)

題目:217. 存在重復元素 示例1: 輸入: nums [1,2,3,1] 輸出: true 解釋: 元素 1 在下標 0 和 3 出現。 示例2: 輸入: nums [1,2,3,4] 輸出: false 解釋: 所有元素都…

Redis 高可用與集群原理

Redis 高可用與集群原理1. 前言 Redis 單機雖然高性能,但一旦節點宕機,數據丟失或服務不可用問題會非常嚴重。為了解決這一問題,Redis 提供了 主從復制、哨兵(Sentinel)、Cluster 集群 等高可用機制。 這一篇文章我們重…

Oracle OCP認證考試題目詳解082系列第31題

考察知識點:SET VERIFY ON命令 英文題目 Which two statements are true about the SET VERIFY ON command? A.It displays values for variables prefixed with && B.It displays values for variables created by the DEFINE command C.It can be used in SQL Dev…