[群晖]此套件需要您启动[pgsql-adapter.service]

这篇具有很好参考价值的文章主要介绍了[群晖]此套件需要您启动[pgsql-adapter.service]。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 打开群晖SSH

默认使用22端口
[群晖]此套件需要您启动[pgsql-adapter.service]

2. 通过SSH工具进入群晖

我这里用的是Xshell

什么ssh工具都可以,不会的朋友请自行学习。

3. 切换root用户

xxx@xxx:/$ sudo -i
Password: 
root@xxx:~#

这里的密码通常是群晖第一个管理员用户密码

4.创建脚本

随意进入到一个目录下(我是在/usr/pgsql),创建“pgsql_analyzer.sh”文件,操作如下:

root@xxx:/# cd /usr/
root@xxx:/usr# mkdir pgsql
root@xxx:/usr# cd pgsql/
root@xxx:/usr/pgsql# vim pgsql_analyzer.sh

此时已创建好了“pgsql_analyzer.sh”文件,并打开了它
接下来我们把以下的脚本粘贴到“pgsql_analyzer.sh”中。

pgsql_analyzer.sh脚本内容:

#!/bin/bash

##################
# Utility functions
##################

syno_getopt()
{
	local opt_cmd="$1"
	shift 1

	while getopts "$opt_cmd" opt; do
		if [[ -z "$OPTARG" ]]; then
			eval "opt_${opt}"="-"
		else
			eval "opt_${opt}"="$OPTARG"
		fi
	done
}

cecho()
{
	local color="$1"
	local message="$2"

	local NC='\033[0m'
	local code

	case "$color" in
		red)    code="1;31" ;;
		green)  code="1;32" ;;
		blue)   code="1;34" ;;
		gray)   code="0;37" ;;
		yellow) code="1;33" ;;
		*)      code="1;37" ;;
	esac

	code='\033['$code'm'
	echo "${code}${message}${NC}"
}

errecho()
{
	echo -e "$@" >&2
}

LOG()
{
	local level="$1"
	local message="$2"
	local timestamp="$(date +'%Y-%m-%d %H:%M:%S')"

	# Echo to screen
	local color
	case "$level" in
		"ERROR"|"WARNING") color="red" ;;
		"NOTICE")          color="blue" ;;
		"INFO")          color="green" ;;
		*)                 color="gray" ;;
	esac

	formatted=$(cecho yellow "$timestamp ")$(cecho $color "[$level] $message")
	errecho $formatted

}

log_check_result()
{
	local name="$1"
	local result="$2"

	if [[ "$result" = "true" || "$result" = "0" ]]; then
		LOG INFO "Running $name ... Pass"
		return 0
	else
		LOG WARNING "Running $name ... Error found, please check messages above."
		return 1
	fi
}

db_query()
{
	local db="$1"
	local sql="$2"

	psql -At -F $'\t' -U postgres $db -c "$sql"
}

##################
# Test functions
##################

findfile()
{
	local pattern="$1"
	local path="$2"
	local files="${path} ${path}.1 ${path}.1.xz ${path}.2.xz"
	local limit=20
	local result=false
	local extentsion file msg

	for file in $files; do
		if [[ ! -f "$file" ]]; then
			continue
		fi

		LOG DEBUG "Searching error message from file: $file ..."
		extension="${file##*.}"

		case "$extension" in
			gz)
				msg="$(zcat "$file" | grep "$pattern" | tail -n $limit)"
				;;
			xz)
				msg="$(xzcat "$file" | grep "$pattern" | tail -n $limit)"
				;;
			*)
				msg="$(cat "$file" | grep "$pattern" | tail -n $limit)"
				;;
		esac

		if [[ -n "$msg" ]]; then
			result=true
			echo "$msg"
			break
		fi
	done

	$result && return 0 || return 1
}

has_permission()
{
	local path="$1"
	local permission="$2"
	local user="$3"
	local group="$4"
	local result=true
	local re f_permission f_user f_group

	# Check path exists
	if [[ ! -e "$path" ]]; then
		LOG ERROR "File or directory does not exists: $path"
		return 1
	fi

	# Check path permission
	if [[ -n "$permission" ]]; then
		re="${permission//-/.}"
		f_permission="$(stat -c "%A" "$path")"

		if [[ ! "$f_permission" =~ $re ]]; then
			LOG ERROR "Permission $permission is not match, path: $path, permission: $f_permission"
			result=false
		fi
	fi

	# Check path user
	if [[ -n "$user" ]]; then
		f_user="$(stat -c "%U" "$path")"

		if [[ "$f_user" != "$user" ]]; then
			LOG ERROR "User $user is not match, path: $path, user: $f_user"
			result=false
		fi
	fi

	# Check path group
	if [[ -n "$group" ]]; then
		f_group="$(stat -c "%G" "$path")"

		if [[ "$f_group" != "$group" ]]; then
			LOG ERROR "Group $group is not match, path: $path, user: $f_group"
			result=false
		fi
	fi

	$result && return 0 || return 1
}

##################
# Test cases
##################


disklog_check()
{
	local files="/var/log/dmesg /var/log/messages"
	local result=true
	local file

	for file in $files; do
		if findfile "exception Emask\|status: {\|error: {\|SError: {" "$file"; then
			LOG ERROR "Disk error(s) are found in $file"
			result=false
		fi
	done

	for file in $files; do
		if findfile "EXT4-fs .*: error\|EXT4-fs error\|EXT4-fs warning\|read error corrected" "$file"; then
			LOG ERROR "Disk ext-4 error(s) are found in $file"
			result=false
		fi
	done

	log_check_result disklog_check $result
}

tune2fs_check()
{
	local devs="/dev/md0 /dev/sda1 $(cut -d ' ' -f 1 /run/synostorage/volumetab)"
	local result=true
	local dev

	for dev in $devs; do
		if tune2fs -l "$dev" 2> /dev/null | grep "FS Error"; then
			LOG ERROR "Filesystem error(s) are found in tune2fs -l $dev"
			result=false
		fi
	done

	log_check_result tune2fs_check $result
}

permission_check()
{
	# Check directory permission
	local volume="$(servicetool --get-service-volume pgsql)"
	local result=true

	has_permission "$volume"                          drwxr-xr-x                   || result=false
	has_permission "${volume}/@database"              drwxr-xr-x admin    users    || result=false
	has_permission "${volume}/@database/pgsql"        drwx------ postgres postgres || result=false

	log_check_result permission_check $result
}

user_check()
{
	# Check root user name and postgres entry point
	local count
	local result=true

	# Check root name
	count=$(cat /etc/passwd | grep -c ':x:0:0:')

	if [[ "$count" -ne 1 ]]; then
		LOG ERROR "User: root has $count rows in /etc/passwd"
		result=false
	fi

	if ! cat /etc/passwd | grep 'root:x:0:0:' > /dev/null 2>&1; then
		LOG ERROR "User: root is not found in /etc/passwd"
		result=false
	fi

	# Check postgres entry point
	count=$(cat /etc/passwd | grep -c 'postgres')
	if [[ "$count" -ne 1 ]]; then
		LOG ERROR "User: postgres has $count rows in /etc/passwd"
		result=false
	fi

	if ! cat /etc/passwd | grep postgres | grep '/var/services/pgsql:/bin/sh' > /dev/nuill 2>&1; then
		LOG ERROR "User: postgres entry point(/var/services/pgsql:/bin/sh) has been modified"
		result=false
	fi

	log_check_result user_check $result
}

pglog_check()
{
	local result=true
	if findfile "FATAL" "/var/log/postgresql.log"; then
		LOG ERROR "Fatal error(s) are found in postgresql log"
		result=false
	fi

	log_check_result pglog_check $result
}

volume_check()
{
	local volume="$(servicetool --get-service-volume pgsql)"
	local result=true
	local avail

	if ! df -BG | grep -q "$volume"; then
		LOG WARNING "Failed to parse volume size, Please check available space of volume manually"
		log_check_result volume_check false
		return
	fi

	# Get available volume space in Gigabytes
	avail=$(df -BG | grep "$volume" | awk '{print $4}' | sed 's/G//g')

	if ((avail <= 1)); then
		LOG ERROR "Available volume space is smaller than 1GB"
		result=false
	fi

	log_check_result volume_check $result
}

calendar_check()
{
	local result=true
	local answer=n

	if tail -n 20 /var/log/postgresql.log | grep '/tmp/synocalendar'; then
		result=false
		read -p "Hit Calendar bug, missing directory: /tmp/synocalendar. Do you want to fix it? (Y/n):" answer
		echo ""

		if [[ -z "$answer" || "$answer" = "Y" || "$answer" = "y" ]]; then
			LOG INFO "Directory created: /tmp/synocalendar. Restart pgsql manullay later ('synoservice --restart pgsql' on DSM6, '/usr/syno/bin/synosystemctl restart pgsql-adapter' on DSM7)."
			mkdir /tmp/synocalendar
			chown postgres:postgres /tmp/synocalendar
		fi
	fi

	log_check_result calendar_check $result
}

##### Main and help function

rebuild_database()
{
	local volume="$(servicetool --get-service-volume pgsql)"
	local path="${volume}/@database/pgsql"
	local dsm_version=`synogetkeyvalue /etc.defaults/VERSION major`

	LOG INFO "Rebuilding database ..."
	
	if [[ "$dsm_version" = "7" ]]; then
		if ! /usr/syno/bin/synosystemctl stop-service-by-reason rebuild pgsql-adapter; then
			LOG ERROR "Failed to stop pgsql"
			return 1
		fi
	else
		if ! synoservice --pause-by-reason pgsql rebuild; then
			LOG ERROR "Failed to stop pgsql"
			return 1
		fi
	fi

	BACKUP_PATH=${path}-$(date -u +"%Y%m%dT%H%M%SZ")
	mv "$path" "$BACKUP_PATH"
	LOG INFO "Backup Success: $BACKUP_PATH"
	rm /var/services/pgsql

	if ! servicetool --set-pgsql; then
		LOG ERROR "Failed to create psgql directory"
		return 1
	fi

	if [[ "$dsm_version" = "7" ]]; then
		if ! /usr/syno/bin/synosystemctl start-service-by-reason rebuild pgsql-adapter; then
			LOG ERROR "Failed to start pgsql"
			return 1
		fi
	else
		if ! synoservice --resume-by-reason pgsql rebuild; then
			LOG ERROR "Failed to start pgsql"
			return 1
		fi
	fi
	LOG INFO "Rebuild done."
}

vacuum_all()
{
	local result=true

	##### List all databases
	dbs="$(db_query postgres 'SELECT datname FROM pg_database WHERE datistemplate = false')"
	echo "Database list: $dbs"


	##### Vaccum
	for db in $dbs; do
		# Skip large size database
		if [[ "$db" = "synoips" ]]; then
			LOG DEBUG "Skip to vacuum $db"
			continue
		fi

		LOG DEBUG "Vacuuming $db"
		if ! db_query $db "VACUUM FULL"; then
			LOG WARNING "Failed to vacuum $db"
			result=false
		fi
	done

	log_check_result vacuum_all $result
}

recreate_database()
{
	local package="$1"
	local db=$(cat /var/packages/${package}/conf/resource | jq -r '.["pgsql-db"]["create-database"][0]["db-name"]')
	local db_tmp="${db}_$(date +'%Y%m%d%H%M%S')"

	if ! db_query postgres "ALTER DATABASE $db RENAME TO $db_tmp"; then
		LOG ERROR "Failed to rename database from $db to $db_tmp"
		return 1
	fi

	if ! synopkghelper update $package pgsql-db; then
		LOG ERROR "Failed to create database for package: $package"
		return 1
	fi
}


show_usage()
{
	cat << EOF
Description:
	Analysis pgsql issues
Usage:
	$0 [options]

Options:
	-h            Show this help
	-r            Rebuild pgsql database
	-d <package>  Recreate database
	-v            Vacuum all databases (exluding synoips)

EOF
}

main()
{
	syno_getopt "hvrd:" "$@"
	shift $((OPTIND-1))

	if [[ -n "$opt_h" ]]; then
		show_usage
		return
	fi

	##### Rebuild database
	if [[ -n "$opt_r" ]]; then
		rebuild_database
		return $?
	fi

	##### Vacuum every databases
	if [[ -n "$opt_v" ]]; then
		vacuum_all
		return $?
	fi


	##### Recreate database for package
	if [[ -n "$opt_d" ]]; then
		recreate_database "$opt_d"
		return $?
	fi

	##### Check
	pglog_check
	disklog_check
	tune2fs_check
	permission_check
	user_check
	volume_check
	calendar_check
}

main "$@"

在shell窗口中,按 i进入编辑模式*
将上面的脚本内容粘贴到窗口中
依次按’ESC、‘:’ 键、‘w’ 键、 'q’键、回车

5.执行pgsql_analyzer.sh

root@xxx:/usr/pgsql# chmod a+x pgsql_analyzer.sh
root@xxx:/usr/pgsql# ./pgsql_analyzer.sh -r
root@xxx:/usr/pgsql# reboot

此时系统会重新启动
启动完成,pgsql就启动好了
 
 
 
 
 
小白第一次写文章,希望能帮助到大家,写的不好请大家见谅。
有意见或建议烦请指出,感谢!
 
最后有个小问题,命令应该用什么样的代码块?我这里用的shell形式,感觉展示效果不好。有哪位大佬知道请帮忙解答一下,非常感谢!文章来源地址https://www.toymoban.com/news/detail-448930.html


到了这里,关于[群晖]此套件需要您启动[pgsql-adapter.service]的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 群晖Docker套件注册Harbor私有镜像仓库,并下载运行自己发布的Docker镜像

    @[群晖Docker套件注册Harbor私有镜像仓库,并下载运行自己发布的Docker镜像] 在进行微服务开发时,一些基础服务组件(Nacos、Redis、Mysql)的运行以及越来越多的业务服务组件的开发,会导致开发者电脑的内存资源紧张,此时我们可以把一些基础服务组件和基本业务组件(认证中

    2024年02月05日
    浏览(54)
  • 利用群晖部署ChatGPT-web服务,不需要代理,直接起飞,搭建你的私人AI助理

    🌟自建chatgpt-web是一个非常实用的AI服务,它可以帮助我们完成很多任务,而且,OpenAI的收费也非常实惠,自用一个月也就一两美刀,真的不贵!💸 🤖需要注册一个账号,获取API的key,就可以开始使用了。而且,OpenAI还有很多实用的功能,比如可以分享给朋友用,保存聊天

    2024年02月13日
    浏览(41)
  • Ubuntu下的自启动(Service启动)

    在Ubuntu中设置Python3命令开机自启需要创建一个systemd service文件,步骤如下: 使用任一文本编辑器,打开一个终端窗口。 在终端中输入以下命令,创建一个.service文件: 在打开的文件中输入以下代码: 其中,my_script.service是服务名称,我的Python脚本在 /path/to/my/script.py,可以根

    2024年02月09日
    浏览(43)
  • 提示程序需要Windows 7 Service Pack 1或更高版本问题如何解决?

    提示这个,不要慌,这个属于电脑的一个组件没有安装或者出现问题,导致的 这个跟软件都是没关系的,纯属是电脑系统的原因   右键桌面“我的电脑”图标,选择“属性”  在这里,你可以看到,正常这里会显示相关的“Service Pack 1”信息 但是确没有,说明,更加确信是

    2024年02月05日
    浏览(63)
  • 群晖NAS无端口域名远程访问,ipv4、ipv6均可,开启https,需要云服务器+frp(内网穿透)+宝塔(反向代理)

     作者:陌路遥 其实这篇文章算不上教程,顶多算是经验总结。因为作者也是小白,也是在不断学习,本文所呈现的方法可能较为繁琐,并不是较为简洁的那种,只给大家做一个参考。大佬勿喷,保命。 其实群晖常用的外网远程访问,除了QC之外,就是ipv6+ddns动态域名解析,

    2024年02月09日
    浏览(74)
  • SQL Server安装提示【需要microsoft.NET Framework 3.5 Service Pack 1】

            我在自己电脑安装SQL Server 2014 的时候遇到了这个问题,SQL Server安装提示【需要microsoft.NET Framework 3.5 Service Pack 1】: 1、打开控制面板: 2、选择“程序”:   3、点击“启动或关闭Windows功能”,把NET Framework 3.5(包括.NET 2.0和3.0)选择上,点击“确定”:   4、加载功

    2024年02月11日
    浏览(49)
  • Android Service启动ANR原理

        在Service组件StartService()方式启动流程分析文章中,针对Context#startService()启动Service流程分析了源码,其实关于Service启动还有一个比较重要的点是Service启动的ANR,因为因为线上出现了上百例的 \\\"executing service \\\" + service.shortName 的异常。      本文中所有源码都只粘贴关键代

    2024年02月15日
    浏览(43)
  • idea微服务启动设置services

    在微服务开发过程中,我们经常要在本地启动很多个微服务,如果一个个在application启动类去启动肯定会很麻烦,效率很低,页面很乱,下面介绍下IDEA开发工具中得Services管理管理功能 idea - Views - Tool Windows - Services 点击之后,我们会发现下面的Sidebar多了一个services,点击 “

    2024年02月11日
    浏览(43)
  • Android WiFi Service启动-Android13

    Android WiFi基础概览 AOSP 文档 心主题 WiFi概览 编译生成对应的jar包: \\\"/apex/com.android.wifi/javalib/service-wifi.jar\\\" 相关WiFi服务: WifiService 、 WifiScanningService 、 RttService 、 WifiAwareService 、 WifiP2pService frameworks/base/services/java/com/android/server/SystemServer.java WifiInjector.java : WiFi依赖性注入器。

    2024年01月21日
    浏览(39)
  • IDEA中启动多个微服务(开启Services管理)

    在微服务开发过程中,我们经常要在本地启动很多个微服务,如果一个个在application启动类去启动肯定会很麻烦,效率很低,页面很乱,下面介绍下IDEA开发工具中得Services管理管理功能,也叫Run Dashboard: 第一步: 点击菜单栏:Views - Tool Windows - Services 第二步: 刚创建好的窗

    2024年02月11日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包