上一篇从整体上讲了下DevOps大概涉及到了哪些内容,以及主要工作流程,接下来我们将分步详细介绍各个部分的使用。

概览

首先从 SonarQube 开始说起,SonarQube 是一个可用于检测重复代码、潜在bug、代码规范、安全性漏洞以及单元测试等,并能够持续分析和评测项目源代码质量的代码质量管理平台。SonarQube由4个部件组成:一个SonarQube Server,一个SonarQube Database,若干SonarQube Plugin,若干SonarScanner。下图取自官方文档.

目前最新版本已经到了8.3,但是本文使用的是SonarQube 7.9 LTS版,因为该版本为最新的长期支持版。这部分先介绍SonarQube Database,因为数据库是基础。

数据库选择

SonarQube目前支持的数据库有PostgreSQL,Microsoft SQL Server,Oracle,说是选择,其实也没什么可选的,早期还支持MySql,但是从7.9开始就已经不再提供支持了(其实依然可以用),开源免费的基本就剩下PostgreSQL了,并且官方也推荐使用PostgreSQL,这也算是释放了一个小小的信号,新的项目可以多考虑考虑用PostgreSQL替代MySql,近几年PostgreSQL发展非常迅速,有兴趣的可以去db-engines看一下数据库排名及趋势。



PostgreSQL排名第四,并且无论同比还是环比都有较高的增长率,而其他排名靠前的数据库环比均有所下滑。说这么多,其实就是一句话,选PostgreSQL就对了。

安装

目前PostgreSQL版本已经到12了,但是SonarQube 7.9 LTS支持的最新版是10,那我们也直接用10,其实PostgreSQL 9就已经够用了,数据库的稳定性往往远大于功能性,通常也不需要最新的版本,新功能通常情况下也用不上。

官网页面,选择对应的版本及系统(我的是CentOS 7),如下图所示:



拷贝如下脚本,逐个执行安装并启动服务。

yum install https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86\_64/pgdg-redhat-repo-latest.noarch.rpm
yum install postgresql10-server -y
/usr/pgsql-10/bin/postgresql-10-setup initdb
systemctl enable postgresql-10
systemctl start postgresql-10

安装完成后,可通过如下命令查看下当前版本:

[root@Node01 ~]# psql --version
psql (PostgreSQL) 10.13

修改密码

PostgreSQL安装成功后,会在Linux系统中默认创建一个postgres用户,必须切换到postgres才可以访问PostgreSQL数据库,root用户无权访问,如下所示:

[root@Node01 ~]# cat /etc/passwd | grep postgres
postgres:x:26:26:PostgreSQL Server:/var/lib/pgsql:/bin/bash
[root@Node01 ~]# psql postgres
psql: FATAL: role "root" does not exist
[root@Node01 ~]# su postgres
bash-4.2$ psql postgres
could not change directory to "/root": Permission denied
psql (10.13)
Type "help" for help. postgres=#

注意,切换postgres用户后可能会提示could not change directory to "/root": Permission denied,这是因为postgres用户没有访问/root目录的权限,可以登录root用户提升postgres用户的权限。当然其实也不需要那么麻烦,直接无视就可以了,因为我们只需要用过postgres用户对PostgreSQL数据库进行操作而已,不需要访问其他资源。

PostgreSQL默认账号也是postgres,没有密码,可以通过下面脚本修改密码(也可以新建一个用户,会更安全,但实际上,数据库外网应该是不能访问的,所以我直接使用默认用户):

alter user postgres with password '123456';

远程访问设置

进入/var/lib/pgsql/10/data目录,修改postgresql.conf配置文件,修改为监听所有IP:

listen_addresses = '*'

修改pg_hba.conf配置文件,添加验证方式,并只接收来自192.168.0.0/16网段的请求:

# IPv4 local connections:
host all all 127.0.0.1/32 ident
host all all 192.168.0.0/16 md5

基本操作

系统命令

下面操作需要切换到postgres用户执行。

操作 说明
psql -l 查看数据库列表
createdb testdb 创建testdb数据库
psql testdb 切换到testdb数据库
dropdb testdb 删除testdb数据库
createuser dbuser 创建dbuser用户
dropuser dbuser 删除dbuser用户

数据库命令

下面操作需要切换到具体的数据库执行。

操作 说明
\h 查看SQL命令帮助
? 查看psql命令帮助
\l 查看数据库列表
\q 退出客户端程序psql
\c 从一个数据库中切换到另一个数据库
\dt 查看表
\d 查看表结构

管理工具

为了操作方便,也可以安装一个可视化的管理工具---pgAdmin,进入yum仓库页面,按步骤安装即可。我只装了web版,并且跟数据库安装在了同一台服务器上,用到的脚本如下:

# 设置仓库
rpm -i https://ftp.postgresql.org/pub/pgadmin/pgadmin4/yum/pgadmin4-redhat-repo-1-1.noarch.rpm
# 仅安装WEB模式
yum install pgadmin4-web -y # 执行脚本完成配置
/usr/pgadmin4/bin/setup-web.sh

到这里,数据库准备好了,下一步我们可以安装SonarQube Server了。

DevOps系列(2)-SonarQube之PostgreSQL的更多相关文章

  1. DevOps系列——Jenkins/Gitlab自动打包部署

    前面只说了DevOps的两个基础组件Jenkins和GitLab,客官也不要着急,我们玩就玩的深入一点,Gitlab和Jenkins的各种配置和 插件很多,也够啃一阵子的,不要照着操作一通就感觉万事大 ...

  2. DevOps系列(1)-总体架构

    扯闲淡 在进入正式话题之前,先扯个淡,这算是第一篇我正式在博客上发布的随笔吧,之前也一直有想写点什么,将自己多年的工作经验分享出来,供大家参考点评,但是奈何一直对自己的文字功底不自信(其实也确实比较烂 ...

  3. 补习系列(19)-springboot JPA + PostGreSQL

    目录 SpringBoot 整合 PostGreSQL 一.PostGreSQL简介 二.关于 SpringDataJPA 三.整合 PostGreSQL A. 依赖包 B. 配置文件 C. 模型定义 ...

  4. Jenkins系列——使用SonarQube进行代码质量检查

    1.目标 之前已经写过一篇关于Jenkins和SonarQube的一篇博客<jenkins集成sonar>,本文在参考前文的基础上,做了详细的补充. 使用SonarQube进行代码质量检查 ...

  5. CODING DevOps 系列第一课:基于开源工具链打造持续交付平台

    当下软件发展趋势 当今 IT 行业发展中比较流行的几个技术,首先是微服务化,将原有的一个系统拆分成多个,意味着有多个系统需要构建.测试.部署和运维. 第二个是敏捷开发模式,需求粒度更细化,要求一个可独 ...

  6. CODING DevOps 系列第三课:云计算、云原生模式下 DevOps 的建设

    本文首先会和大家分享当前整个应用生命周期的演变历程,然后讲解云计算模式下 DevOps 建设包含的过程.流程规范和标准,最后讲解云原生时代到来会带来哪些改变,以及标准化的建设会有哪些改变和突破. 应用 ...

  7. CODING DevOps 系列第四课:DevOps 中的质量内建实践

    什么是质量内建 随着时间的推移,我们项目的开发效率会逐渐降低,直到几年之后整个项目可能就无法维护,只能推倒重来.具体的表现首先就是随着时间推移,我们会发现整个需求列表里面能做的需求越来越少,因为每当我 ...

  8. CODING DevOps 系列第五课:微服务测试——微服务下展开体系化的微服务测试

    微服务测试的痛点与挑战 这张图可以形象地展示单体服务和微服务的对比,单体应用就像左边巨大的集装箱,软件模块和应用都包括其中:而微服务就像是由一个小集装箱组成,微小的服务组成一个庞大.完整的系统.单体服 ...

  9. 【Azure DevOps系列】什么是Azure DevOps

    DevOps DevOps是一种重视"软件开发人员(Dev)"和"IT运维技术人员(Ops)"之间沟通合作的文化,它促进开发和运营团队之间的协作,以自动化和可重 ...

随机推荐

  1. Java锁_读写锁

    独占锁:是指锁一次只能被一个线程持有,ReentrantLock和Synchronized都是独占锁. 共享锁:是指锁可以被多个线程持有. 对于ReentrantReadWriteLock,其读锁是共 ...

  2. 10-Pandas之数据融合(pd.merge()、df.join()、df.combine_first()详解)

    一.pd.merge() pd.merge()的常用参数 参数 说明 left 参与合并的左侧DataFrame right 参与合并的右侧DataFrame how 如何合并.值为{'left',' ...

  3. PHP trigger_error() 函数

    定义和用法 trigger_error() 函数创建用户自定义的错误消息. trigger_error() 函数用于在用户指定的条件下触发一个错误消息.它可以与内建的错误处理程序一起使用,或者与由 s ...

  4. PHP preg_quote() 函数

    preg_last_error 函数用于转义正则表达式字符.高佣联盟 www.cgewang.com 语法 string preg_quote ( string $str [, string $del ...

  5. PHP constant() 函数

    实例 返回一个常量的值: <?php//define a constantdefine("GREETING","Hello you! How are you tod ...

  6. Spring Joinpoint

    如果用maven管理 则需要 <artifactId> aopalliance </artifactId> <artifactId> spring-aspects ...

  7. 原来写个Vue 首页就这么简单

    全栈的自我修养: 为我们的项目添加首页 You can never replace anyone. What is lost is lost. 每个人都是无可替代的,失去了便是失去了. 前言 上篇文章 ...

  8. 虚拟机安装Centos(VirtulBox)

    阿里云服务器本月底到期了,之前自己犹豫不觉没上279元3年服务器的车,但是又要用linux,所以有了这篇文章. VirtulBox 一款开源的虚拟化主机应用,可以实现一台电脑上运行多个操作系统(Lin ...

  9. 系统UISearchController详解

    原文链接:https://www.jianshu.com/p/aa9a153a5b58

  10. python8.4景区买票

    from threading import Threadimport threadinglock=threading.Lock()num=100#定义买票方法def sale(name): lock. ...