深度體驗與測評openGauss 6.0.0新版本

来源:https://www.cnblogs.com/huaweiyun/p/18241468
-Advertisement-
Play Games

openGauss 6.0.0版本在安裝和使用方面都帶來了很大的改進和優化。一站式交互安裝功能極大地簡化了安裝流程,降低了用戶的學習成本;性能優化和中文日誌支持功能則進一步提升了資料庫的穩定性和易用性。 ...


本文分享自華為雲社區《openGauss 6.0.0新版本安裝測評》,作者:馬順華。

前言

近日,備受矚目的openGauss 6.0.0版本正式上線,作為國產資料庫的佼佼者,openGauss一直致力於為用戶提供高效、穩定的資料庫解決方案。恰逢openGauss社區舉辦的第七屆openGauss技術文章徵集活動正式開啟,我有幸親身體驗了這一新版本,併在此分享我的安裝及使用測評。

一、安裝體驗

openGauss 6.0.0版本在安裝方面進行了重大改進,推出了全新的一站式交互安裝功能。這一功能極大地簡化了安裝流程,降低了用戶的學習成本。在安裝過程中,用戶只需通過交互界面輸入資料庫的相關信息,系統便會自動生成xml配置文件,並自動進行資料庫的初始化安裝。相比之前的版本,這一改變無疑是一大亮點。

在實際安裝過程中,我按照提示逐步操作,整個過程流暢無阻。值得一提的是,openGauss 6.0.0版本還解除了對root用戶的依賴,進一步提升了安裝的安全性。安裝完成後,我成功啟動了資料庫服務,併進行了基本的測試。

二、使用體驗

性能優化:openGauss 6.0.0版本在性能方面進行了優化,特別是在主備複製方面。通過實際測試,我發現新版本在數據同步和故障恢復方面表現優異,能夠滿足大多數業務場景的需求。

中文日誌支持:新版本還增加了中文日誌支持功能,這一功能對於國內用戶來說非常實用。通過查看中文日誌,用戶可以更直觀地瞭解資料庫的運行狀態和錯誤信息,從而更快速地定位問題併進行修複。

多版本支持:openGauss 6.0.0版本提供了企業版和輕量版兩個安裝版本供用戶選擇。企業版適用於大規模、高性能的業務場景,而輕量版則更加適合小規模、輕量級的應用。這種多版本的支持策略使得openGauss能夠滿足不同用戶的需求。

三、安裝準備

本章詳細介紹openGauss極簡安裝的環境準備和配置,極簡安裝包括單節點安裝和一主一備節點安裝,請在安裝之前仔細閱讀本章的內容。如果已完成本章節的配置,請忽略。

1、獲取安裝包

openGauss開源社區上提供了安裝包的獲取方式。

本次試驗環境如下:(根據實際軟硬體情況,選擇不同的安裝包)

架構 :x86x_64

操作系統:Centos 7.6

軟體包:openGauss_6.0.0-RC1 極簡版

2、下載到伺服器

[root@worker1 soft]# ls
openGauss-6.0.0-RC1-CentOS-64bit.tar.bz2
[root@worker1 soft]# 

c237461fa854fff129f1aabf72b0f8b0_20240517-f0bb6e79-6152-4252-bbd9-9f4c87ccc29b.png

3、系統環境配置

3.1 目前僅支持在防火牆關閉的狀態下進行安裝。

[root@worker1 soft]# sestatus
SELinux status:                 disabled
[root@worker1 soft]# 
[root@worker1 soft]# systemctl status firewalld
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)
[root@worker1 soft]# 

2b5fd09b005eeb8ad1652e745070917a_20240517-b3f5234f-3789-4e82-b4b9-d27f6aba5956.png

3.2 設置字元集參數

將各資料庫節點的字元集設置為相同的字元集,可以在/etc/profile文件中添加“export LANG=XXX”(XXX為Unicode編碼)。

en_US.UTF-8

[root@worker1 soft]# echo 'export LANG=en_US.UTF-8' >>/etc/profile
[root@worker1 soft]# 

c5a23e186b43f7adb38e64704f49b6dc_20240517-2b0deed6-e793-476d-a933-bec12975e653.png

3.3 關閉RemoveIPC

在各資料庫節點上,關閉RemoveIPC。CentOS操作系統預設為關閉,可以跳過該步驟。、

RemoveIPC=no

4b27cc879aa858c0511e47cb7e01d3e3_20240517-cdc28759-16b7-45ed-9e06-72db57feab5c.png

3.4 關閉HISTORY記錄

HISTSIZE=0

e3f6aded75db4407ebd9ecfd5d3554fd_20240517-d1d0a8b0-1e36-4a52-9400-c128595cad91.png

4、創建用戶和組

4.1 創建用戶組dbgroup。

[root@worker1 ~]# 
[root@worker1 ~]# groupadd dbgroup
[root@worker1 ~]# 

5bb4149d70950473f138de4b2d4bb1fa_20240517-9af53ca6-c6b8-46ed-84e8-9206c509655e.png

4.2 創建用戶組dbgroup下的普通用戶omm,並設置普通用戶omm的密碼。

[root@worker1 ~]# useradd -g dbgroup omm
[root@worker1 ~]# passwd omm
Changing password for user omm.
New password: 
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@worker1 ~]# 

66a05f207caa8f492367f4cfb28a64af_20240517-b4acbc3b-5364-40fd-9c77-1b92715a71be.png

四、單節點安裝

前提條件

  • 已完成用戶組和普通用戶的創建。
  • 所有伺服器操作系統和網路均正常運行。
  • 普通用戶必須有資料庫包解壓路徑、安裝路徑的讀、寫和執行操作許可權,並且安裝路徑必須為空。
  • 普通用戶對下載的openGauss壓縮包有執行許可權。
  • 安裝前請檢查指定的openGauss埠是否被占用,如果被占用請更改埠或者停止當前使用埠進程。

1、用戶登錄

使用普通用戶登錄到openGauss包安裝的主機,解壓openGauss壓縮包到安裝目錄(假定安裝目錄為/opt/software/openGauss,請用實際值替換)。

[root@worker1 soft]# ls
openGauss-6.0.0-RC1-CentOS-64bit.tar.bz2
[root@worker1 soft]# tar -jxf openGauss-6.0.0-RC1-CentOS-64bit.tar.bz2 -C /opt/software/openGauss/
[root@worker1 soft]# 

3fb989cfbc09a714114083d170846e88_20240517-e73bbfab-39fe-4574-9491-4dadfe6d4a74.png

如果報錯沒有許可權

[omm@worker1 soft]$ tar -jxf openGauss-6.0.0-RC1-CentOS-64bit.tar.bz2 -C /opt/software/openGauss/
tar: ./bin: Cannot mkdir: Permission denied
tar: ./bin: Cannot mkdir: Permission denied

938b8492bc17f5dbe8126a27db7bdd15_20240517-e1a3f22f-6cd8-4698-9cf3-16995109e88b.png

切換為root用戶後添加許可權就可以了

[root@worker1 opt]# chown omm:dbgroup /opt/software/openGauss/
[root@worker1 opt]# chmod 755 /opt/software/openGauss/

889dd17f0e304d83eac36a0a2c04c637_20240517-7f0d8543-9adf-4319-bffb-47c7e9ff2177.png

2、解壓

假定解壓包的路徑為/opt/software/openGauss,進入解壓後目錄下的simpleInstall。

[root@worker1 soft]# cd /opt/software/openGauss/simpleInstall
[root@worker1 simpleInstall]# ls
finance.sql  install.sh  README.md  school.sql
[root@worker1 simpleInstall]# 

9f09b6d606be98c7c53f4c145d9654f8_20240517-20560cd7-d6ef-457e-9328-f40e6ef31ac2.png

3、腳本安裝

執行install.sh腳本安裝openGauss。

[root@worker1 simpleInstall]# sh install.sh  -w "openGauss666" &&source ~/.bashrc
[step 1]: check parameter
Error: can not install openGauss with root
[root@worker1 simpleInstall]# 

安裝報錯

[omm@worker1 simpleInstall]$ sh install.sh  -w "openGauss666" &&source ~/.bashrc
[step 1]: check parameter
[step 2]: check install env and os setting
On systemwide basis, the maximum number of SEMMNI is not correct. the current SEMMNI value is: 128. Please check it.
The required value should be greater than 321. You can modify it in file '/etc/sysctl.conf'.
[omm@worker1 simpleInstall]$ 

解決辦法:

用root登錄修改所需的值應大於321,然後執行sysctl -p

[root@worker1 ~]# 
[root@worker1 ~]# sysctl -w kernel.sem="250 85000 250 330" 
kernel.sem = 250 85000 250 330
[root@worker1 ~]# 

5cd1fb304817d30f971b9d56fe328caf_20240517-17459f2b-52c2-4077-b828-f4297929c96b.png

再次執行install.sh腳本安裝openGauss。

[omm@worker1 simpleInstall]$ sh install.sh  -w "openGauss666" &&source ~/.bashrc

[2024-05-17 16:39:10.010][7802][][gs_ctl]:  done
[2024-05-17 16:39:10.010][7802][][gs_ctl]: server started (/opt/software/openGauss/data/single_node)
import sql file
Would you like to create a demo database (yes/no)? 

4、完成安裝

ecc664481cdcf76f3779fe39ef943963_20240517-0e420f23-e3c8-45c2-9fb6-fde00a8b1c77.png

5、檢查安裝進程

安裝執行完成後,使用ps和gs_ctl查看進程是否正常。

[omm@worker1 simpleInstall]$ 
[omm@worker1 simpleInstall]$ ps ux | grep gaussdb
omm        7805  2.2  2.8 6267816 922936 ?      Ssl  16:39   0:04 /opt/software/openGauss/bin/gaussdb -D /opt/software/openGauss/data/single_node
omm        8180  0.0  0.0 110480   908 pts/0    S+   16:42   0:00 grep --color=auto gaussdb
[omm@worker1 simpleInstall]$ 

d508f1f93b50a9acafda2f0979c1d9af_20240517-a6867ed2-9b03-405e-9a07-b34b4211ea98.png

ps ux | grep gaussdb
gs_ctl query -D /opt/software/openGauss/data/single_node

5.1 執行ps命令,顯示類似如下信息:

omm 20377 0.0 0.0 119880 1216 pts/0 S+ 15:37 0:00 grep --color=auto gaussdb

5.2 執行gs_ctl命令,顯示類似如下信息:

 HA state:           
    local_role                     : Normal
    static_connections             : 0
    db_state                       : Normal
    detail_information             : Normal

 Senders info:       
No information 
 Receiver info:      
No information 
[omm@worker1 simpleInstall]$ 

729dbc835c12929b1eb840c3d9a8045d_20240517-2130bc10-3a3f-41bd-9cd0-1238b6264d4c.png

五、資料庫的增刪改查

1、連接本地連接資料庫

gsql ((openGauss 6.0.0-RC1 build ed7f8e37) compiled at 2024-03-31 11:59:31 commit 0 last mr  )
Non-SSL connection (SSL connection is recommended when requiring high-security)
Type "help" for help.

openGauss=# 

4d13cb4cb28d3439573bdacae962bf33_20240517-29875966-b6a5-4a72-8e2c-d5a733e14b2d.png

登錄埠可以查看 postgresql.conf文件

[omm@worker1 single_node]$ cat postgresql.conf |grep port
port = 5432                # (change requires restart)
#ssl_renegotiation_limit = 0        # amount of data between renegotiations, no longer supported
                    # supported by the operating system:

33650eb673e39e22b0f692f0c5bd405e_20240517-28909fa4-8d0d-4c23-baa6-3060b72bb338.png

2、創建資料庫

資料庫安裝完成後,預設生成名稱為postgres的資料庫。您需要自己創建一個新的資料庫。

openGauss=# CREATE DATABASE database_openGauss;
CREATE DATABASE
openGauss=# 

40bfaf9f583acfd4b95c167fef7ed534_20240517-04e3a41d-f72b-4032-9af8-3b04ba38aa2f.png

3、查看資料庫

3.1 使用“\l”用於查看已經存在的資料庫。

\l

openGauss=# \l
                                   List of databases
        Name        | Owner | Encoding |   Collate   |    Ctype    | Access privileges 
--------------------+-------+----------+-------------+-------------+-------------------
 database_opengauss | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 finance            | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 postgres           | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 school             | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0          | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
                    |       |          |             |             | omm=CTc/omm
 template1          | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
                    |       |          |             |             | omm=CTc/omm
(6 rows)

openGauss=# 

9856027e1967a6094475a2b1ad33fd58_20240517-841718f9-e622-4183-a9ac-3d210aba2eea.png

3.2 使用 “\c + 資料庫名” 進入已存在資料庫。

openGauss=# 
openGauss=# \c database_opengauss
Non-SSL connection (SSL connection is recommended when requiring high-security)
You are now connected to database "database_opengauss" as user "omm".
database_opengauss=# 

6ef2a712f8ea1b3f3345b0b5b015de83_20240517-02321ce4-5ac0-4b48-b8a8-d4b2711696b6.png

4、修改資料庫

ALTER DATABASE database_opengauss RENAME TO new_name666;

openGauss=# ALTER DATABASE database_opengauss RENAME TO new_name666;
ALTER DATABASE
openGauss=# \l
                               List of databases
    Name     | Owner | Encoding |   Collate   |    Ctype    | Access privileges 
-------------+-------+----------+-------------+-------------+-------------------
 finance     | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 new_name666 | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 postgres    | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 school      | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0   | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
             |       |          |             |             | omm=CTc/omm
 template1   | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
             |       |          |             |             | omm=CTc/omm
(6 rows)

openGauss=# 

7b69ca6df9cc5af5222cb017fa0959d2_20240517-e6561c73-7395-4683-99a8-e2fc19720fb9.png

5、刪除資料庫

openGauss=# DROP DATABASE new_name666 ;
DROP DATABASE
openGauss=# \l      
                              List of databases
   Name    | Owner | Encoding |   Collate   |    Ctype    | Access privileges 
-----------+-------+----------+-------------+-------------+-------------------
 finance   | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 postgres  | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 school    | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0 | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
           |       |          |             |             | omm=CTc/omm
 template1 | omm   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/omm           +
           |       |          |             |             | omm=CTc/omm
(5 rows)

openGauss=# 

總結

openGauss 6.0.0版本在安裝和使用方面都帶來了很大的改進和優化。一站式交互安裝功能極大地簡化了安裝流程,降低了用戶的學習成本;性能優化和中文日誌支持功能則進一步提升了資料庫的穩定性和易用性。通過實際測試,我認為openGauss 6.0.0版本是一款非常優秀的國產資料庫產品,值得廣大用戶嘗試和使用。

cke_44166.png

HDC 2024,6月21日-23日,東莞松山湖,期待與您相見!

更多詳情請關註官網:

中文:https://developer.huawei.com/home/hdc

英文:https://developer.huawei.com/home/en/hdc

點擊關註,第一時間瞭解華為雲新鮮技術~

 


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

-Advertisement-
Play Games
更多相關文章
  • 目錄題目分析代碼結果 題目 利用聚合API平臺的API介面,利用HTTP協議向伺服器發送請求,並接受伺服器的響應,要求利用cJSON庫對伺服器的響應數據進行解析,並輸出到終端 分析 1.需從代碼托管網站GitHub或SourceForge代碼網站下載cJSON庫及閱讀下載的README相關手冊如何使 ...
  • 目錄題目註意事項實現代碼結果展示相關介面指引 題目 利用某些平臺(聚合API、百度AI、科大訊飛API)的API介面,利用HTTP協議向伺服器發送請求,並接受伺服器的響應,要求利用cJSON庫對伺服器的響應數據進行解析,並輸出到終端。 註意事項 1.預測的日期開始時間為2010-01-01 2."老 ...
  • 在Linux系統中使用Certbot為Nginx安裝SSL證書併進行配置,通常遵循以下步驟: 1. 安裝Certbot 首先確保你的系統已經安裝了EPEL倉庫,如果沒有安裝,可以通過以下命令安裝:sudo yum install epel-release 接著安裝Certbot:sudo yum i ...
  • 想使用Windows的計劃任務來實現:當電腦空閑時,自動關機,以避免資源浪費。 方案一 測試了多個軟體,如Shutter,WinOFF Setup,它們功能豐富,但僅能在用戶登錄時運行。而Windows 11會在一段時間後自動註銷用戶,儘管嘗試多種設置方法,問題仍未解決。 方案二 編寫了AI程式來 ...
  • liwen01 2024.06.09 前言 Linux系統中的ext2、ext3、ext4 文件系統,它們都有很強的向後和向前相容性,可以在數據不丟失的情況下進行文件系統的升級。目前ext4是一個相對較成熟、穩定且高效的文件系統,適用於絕大部分規模和需求的Linux環境。 ext4它突出的特點有:數 ...
  • V1.0 2024年6月11日 發佈於博客園 目錄 目錄目錄線程池原理線程池是什麼線程池解決的問題動態創建子線程的缺點線程池相關介面線程池相關結構體struct task 任務節點線程池介面init_pool() 線程池初始化線程池初始化流程圖add_task() 向線程池添加任務add_threa ...
  • GaussDB作為企業級的資料庫,經過了多年的技術發展,具備豐富的技術特性,使用LLVM技術後提升了系統的查詢性能,使得開發者在OLAP和OLTP多場景中均受益。 ...
  • 通過本文的介紹,我們瞭解了騰訊雲 BI 這款商業智能解決方案的基本功能和應用場景。從創建項目、連接數據源、數據表建模到頁面搭建和推送功能的設置,我們通過一個互聯網運營看板的案例,展示瞭如何快速入門並利用騰訊雲 BI 進行數據分析和可視化。通過簡單的數據編輯,我們可以輕鬆地設計報表,並實現數據的可視化... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...