问: 如何从Bash脚本本身中获得其所在的目录? 我想使用Bash脚本作为另一个应用程序的启动器。我想把工作目录改为Bash脚本所在的目录,以便我可以对该目录下的文件进行操作,像这样: $ ....但是在以相对路径的方式去执行脚本时,获取的目录信息是相对路径,不能满足其他需要获取绝对路径的场景。 如果要获取绝对路径,可以使用如下方法: #!...$script_dir 其中第3行代码,无论从何处调用它,都将为你提供脚本的完整目录路径。...测试结果如下: 另外,可以根据第一种方法结合使用 realpath 命令,也可获取脚本所在目录的绝对路径: #!.../(点-斜杠),以便在bash中运行它 shell脚本对编码和行尾符敏感吗
大多数 Linux 管理员使用 SAR 报告监控系统性能,因为它会收集一周的性能数据。但是,你可以通过更改 /etc/sysconfig/sysstat 文件轻松地将其延长到四周。...如果超过 28,那么日志文件将放在多个目录中,每月一个。 要将覆盖期延长至 28 天,请对 /etc/sysconfig/sysstat 文件做以下更改。...在本文中,我们添加了三个 bash 脚本,它们可以帮助你在一个地方轻松查看每个数据文件的平均值。 这些脚本简单明了。出于测试目的,我们仅包括两个性能指标,即 CPU 和内存。...你可以修改脚本中的其他性能指标以满足你的需求。 从 SAR 报告中获取平均 CPU 利用率的 Bash 脚本 该 bash 脚本从每个数据文件中收集 CPU 平均值并将其显示在一个页面上。...2:从 SAR 报告中获取平均内存利用率的 Bash 脚本
在Bash 脚本中比较字符串的需求相对普遍,可用于在继续执行脚本的下一部分之前检查某些条件。 字符串可以是任何字符序列。...在本教程中,我们将向您展示如何在Linux 系统上比较Bash 脚本中的字符串,我们将在一个简单的 if/else Bash 脚本的上下文中展示这一点,这样您就可以看到在开发脚本时测试这种情况是如何工作的...在本教程中,您将学习: 如何在 Bash 中比较字符串 比较字符串的 if/else Bash 脚本示例 Bash 脚本:字符串比较示例 例1 在 Bash 脚本中,您通常会将一个或两个字符串存储为变量...总结 在本教程中,我们了解了如何在 Bash 脚本中比较字符串,尤其是在 Bash 脚本的上下文中if/else。...当然,此功能可以扩展到更健壮的脚本,这些脚本可以读取用户的输入或使用 case 运算符等。这些都是在 Bash 中比较字符串所需的所有比较方法。
更多好文请关注↑ 问: 我想从字符串中删除前缀/后缀。例如,给定: string="hello-world" prefix="hell" suffix="ld" 如何获得以下结果?...如果模式与 parameter 扩展后的值的开始部分匹配,则扩展的结果是从 parameter 扩展后的值中删除最短匹配模式(一个 # 的情况)或最长匹配模式(## 的情况)的值 ${parameter...如果模式与 parameter 扩展后的值的末尾部分匹配,则扩展的结果是从 parameter 扩展后的值中删除最短匹配模式(一个 % 的情况)或最长匹配模式(%% 的情况)的值。...https://www.gnu.org/software/bash/manual/bash.html#Shell-Parameter-Expansion 相关阅读: 在bash中:-(冒号破折号)的用法...在Bash中如何将字符串转换为小写 在shell编程中$(cmd) 和 `cmd` 之间有什么区别 如何从Bash变量中删除空白字符 更多好文请关注↓
问: 假设我有这个脚本: export.bash #!.../usr/bin/env bash export VAR="HELLO, VAR" 当我执行脚本并尝试访问 $VAR 时,我没有得到任何值!...在调用 shell 的上下文中执行脚本: $ cat set-vars1.sh export FOO=BAR $ . set-vars1.sh $ echo $FOO BAR 另一种方法是在脚本中打印设置环境变量的命令...-f 指 shell 函数 -n 从每个(变量)名称中删除 export 属性 -p 显示所有导出变量和函数的列表 ---- 参考: stackoverflow question 16618071...help eval 相关阅读: 用和不用export定义变量的区别 在shell编程中$(cmd) 和 `cmd` 之间有什么区别 ----
前言 公司使用的是 PostgreSQL 数据库,可以使用 pgAdmin 或者 DBeaver 进行连接该数据库。个人更喜欢用 DBeaver,因为其界面更加美观,操作也相对简单。...DBeaver 是一个通用的数据库管理工具和 SQL 客户端,支持 MySQL, PostgreSQL, Oracle, DB2, MSSQL, Sybase, Mimer, HSQLDB, Derby...DBeaver 提供一个图形界面用来查看数据库结构、执行 SQL 查询和脚本,浏览和导出数据,处理 BLOB/CLOB 数据,修改数据库结构等等。...双击单引号/双引号的内侧可以直接选定被单引号/双引号包括起来的内容。...导出DBeaver的连接配置和脚本文件 DBeaver默认的连接和脚本(Connections和Scripts)都保存在General这个project里的.dbeaver-data-sources.xml
虽然在面试中SQL都是大差不差的,但是在实操中,恰好是差得那一点经常让人头秃,比如我用习惯了mysql,切换到pgsql之后经常在一些细节上写错,再到使用sql server也是一样,属于大错不犯小错不断的情况...除了上面这种写法,还支持这种写法: SELECT name[1:3] AS initials FROM students; 4.分页查询语法 MySQL和PostgreSQL都是使用LIMIT和OFFSET...关键字实现分页查询。...SELECT DATE_FORMAT(created_at, '%Y-%m-%d') AS date FROM products; PostgreSQL:使用TO_CHAR函数进行日期格式化。...CREATE TABLE my_table ( is_active BIT ); 7.数据引用方式 MySQL使用反引号`` select `姓名` from student; PostgreSQL
4.2 查询数组变量 查询数组变量的单个元素值可以使用索引查找(索引值是从 0 开始的),比如查找数组第 3 个元素值: echo ${array[2]} 查询整个数组变量可用 * 作为通配符作为索引值...如果设置了且非空,就用作格式化字符串,以显示 Bash 历史中每条命令的时间戳 HISTIGNORE 由冒号分隔的模式列表,用来决定历史文件中哪些命令会被忽略 HISTSIZE 最多在历史文件中存多少条命令...,能够覆盖 LANG 变量 LC_COLLATE 设置对字符串排序时用的排序规则 LC_CTYPE 决定如何解释出现在文件名扩展和模式匹配中的字符 LC_MESSAGES 在解释前面带有 $ 的双引号字符串时...,该环境变量决定了所采用的语言环境设置 LC_NUMERIC 决定着格式化数字时采用的语言环境设置 LINENO 当前执行的脚本的行号 LINES 定义了终端上可见的行数 MACHTYPE 用「CPU-...当 * 用双引号括起时,即 " 6.4 $@ 当 @ 未用双引号括起时,即 @:等同于 当 @ 用双引号括起时,即 " 【注】* 和 @ 的使用很容易混淆,为了更好地理解可以参见以下例子: 首先定义脚本文件
今天,我们就以PostgreSQL数据库为例,介绍如何使用DO块或存储过程来实现脚本的幂等性。 什么是幂等性? 在计算机科学中,幂等性是一个重要的概念。...这在很多情况下都是非常有用的,比如在软件升级时,我们可能需要运行脚本来升级数据库,如果这个脚本是幂等的,那么无论我们执行多少次,都不会对数据库产生负面影响。 如何实现幂等性?...这意味着你可以在多个查询或者会话中调用同一个存储过程。而DO块中的代码在执行之后,就会被丢弃,不会被保存在数据库中。 存储过程可以返回结果,这意味着你可以使用存储过程来查询数据,或者计算一些值。...结论 在编写数据库初始化脚本时,通过合理使用PostgreSQL中的DO块或存储过程,我们可以有效地实现脚本的幂等性,这对于系统升级和数据库的维护来说,是非常重要和有用的。...希望这篇文章能够帮助到在使用PostgreSQL的你,或者激发你对其他数据库中类似功能的探索。
有时还会需要脚本能够与使用者交互。bash shell提供了一些不同的方法来从用户处获得数据, 包括命令行参数,命令行选项,以及直接从键盘读取输入的能力。...image.png 2.在脚本中使用getopt 可以在脚本中使用getopt来格式化脚本所携带的任何命令行选项或者参数,用起来略繁琐。...14.5 将选项标准化 有一些选项是标准化了,约定俗成的东西。自己写的脚本中可以支持这些选项。这样用户使用你的脚本就不用查手册了。...为此提供了read命令 14.6.1 基本的读取 read命令从标准输入或另外一个文件描述符中接收输入。收到输入后read将数据放进一个变量中去。...9 else 10 echo "Falied, Two inconsistent" 11 fi 14.6.4 从文件中读取 每次调用read命令,它都会从文件中读取一行文本。
单引号与双引号字符串 单引号字符串限制: 单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的; 单引号字串中不能出现单独一个的单引号(对单引号使用转义符后也不行),但可成对出现,作为字符串拼接使用...echo $greeting $greeting_1 Shell 数组 bash支持一维数组,不支持多维数组,并且没有限定数组的大小。类似C语言,数组的元素下标也是从0开始。...后台运行的最后一个进程的ID号 $* 以一个单字符形式显示所有向脚本传递的参数,” 12 … $n”的形式输出所有参数 $@ 与相同,但是使用时加引号,并在引号中返回每个参数。...如∗相同,但是使用时加引号,并在引号中返回每个参数。如”@”用「”」括起来的情况、以”1″”2″ … “$n” 的形式输出所有参数。 $- 显示Shell使用的当前选项,与set命令功能相同。 $?...printf 使用引用文本或空格分隔的参数,外面可以在 printf 中使用格式化字符串,还可以制定字符串的宽度、左右对齐方式等。
cURL支持格式化输出请求的详细信息(请参阅cURL手册页的-w、–write out获取更多信息)。 如题,我们只关注如何知晓cURL请求的时间细节, 下面时间以s为单位。 1....-o /dev/null 将请求的输出重定向到/dev/null -s 通知cURL不显示进度条 "http://wordpress.com/" 是我们请求的URL,请使用引号包围(尤其当你的URL包含...time_appconnect:SSL/SSH等上层协议建立连接的时间,比如 connect/handshake 的时间 time_pretransfer:从请求开始到响应开始传输的时间 time_starttransfer.../.curl-format.txt\" -o /dev/null -s " 制作成Linux/Mac 独立脚本 脚本不需要单独的包含格式化的文本。...在可执行路径中,创建名为curltime的文件,粘贴下面内容: #!
在使用 Logstash 从 pg 库中将一张表导入到 ES 中时,发现 ES 中的数据量和 PG 库中的这张表的数据量存在较大差距。如何快速比对哪些数据没有插入?...导入过程中,Logstash 日志没有异常。PG 中这张表有 7600W。 Q2:mq 异步双写数据库、es 的方案中,如何保证数据库数据和 es 数据的一致性?...2.1 方案探讨 要找出哪些数据没有插入到 Elasticsearch 中,可以采用以下方法: 确保 Logstash 配置文件中的 input 插件的 JDBC 驱动程序正确配置,以便从 PostgreSQL...2.2 比较脚本的实现 以下是一个简单的 Shell 脚本示例,用于比较 Logstash 输出文件(JSON 格式)和 PostgreSQL 数据库中的数据。...中的双引号 sed -i 's/"//g' logstash_ids.txt # 对 Logstash 和 PostgreSQL 的 ID 文件进行排序 sort -n logstash_ids.txt
但是我不知道它是如何工作的,有人能解释一下吗? 我主要指的是cat 输出到文件,>>追加到文件,<从文件读取输入。 <<到底是做什么的? 它有man page吗?...答: 源自man bash: Here Documents 这种重定向指示shell从当前源读取输入,直到看到只包含word的行(后面没有空格)。...如果word中的任何字符被加引号,则分隔符是word中删除引号的结果,并且here-document中的行不会展开。...如果重定向操作符是<<-,则从输入行和包含分隔符的行中删除所有前导制表符。这使得shell脚本中的here-documents可以以一种自然的方式缩进。...为了便于理解 word 不加引号和加了引号的区别,我们可以做一个测试,运行截图如下: Here Documents 是一种强大的工具,可以用来向脚本或命令提供复杂的多行输入,例如 SQL 查询、配置文件内容等
bash完全兼容sh,也就是说,用sh写的脚本可以不加修改的在bash中执行 二、shell特点 简单性:Shell是一个高级语言;通过它,你可以简洁地表达复杂的操作。...可移植性:使用POSIX所定义的功能,可以做到脚本无须修改就可在不同的系统上执行。 开发容易:可以在短时间内完成一个功能强大又妤用的脚本。 三、常见错误 报错:-bash: ..../test.sh #执行脚本 实例二 脚本使用read命令从stdin(标准输入)获取输入并赋值给PERSON变量,最后在stdout(标准输出)上输出 #!...$# 传递给脚本或函数的参数个数。 $* 传递给脚本或函数的所有参数。 $@ 传递给脚本或函数的所有参数。被双引号(" ")包含时,与 $* 稍有不同,下面将会讲到。 $?...六、字符串&数组 单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的; 单引号字串中不能出现单引号(对单引号使用转义符后也不行)。
位置参数变量: 这种变量主要是用来向脚本当中传递参数或数据的,变量名不能自定义,变量作用是固定的。 预定义变量: 是Bash中已经定义好的变量,变量名不能自定义,变量作用也是固定的。...可是在Shell脚本中,exit语句是用来退出当前脚本的。也就是说,在Shell脚本中,只要碰到了exit语句,后续的程序就不再执行,而直接退出脚本。...exit的语法如下: exit [返回值] 如果exit命令之后定义了返回值,那么这个脚本执行之后的返回值就是我们自己定义的返回值。可以通过查询$?这个变量,来查看返回值。...-f 从脚本中读取awk命令 -m 对val值设置内在限制 我们这里先来学习awk基本用法,也就是只看看格式化输出动作是干什么的。...-f 脚本文件名: 从sed脚本中读入sed操作。和awk命令的-f非常类似。 -r: 在sed中支持扩展正则表达式。
运行脚本的两种方式 将脚本作为bash的命令行参数 将脚本作为命令行参数时的运行方式如下(#号后面的文本是注释,不必输入到命令行中): $ bash script.sh #假设脚本位于当前目录下 或者...$ bash /home/path/script.sh #使用script.sh的完整路径 如果将脚本作为bash的命令行参数来运行,那么就用不着脚本中的shebang了。...这组命令来自位于用户主目录中的脚本文件~/.bashrc(对于登录shell则是~/.bash_profile)。...在终端中打印文本是绝大多数shell脚本和工具日常需要执行的基本任务。...[root@entel1 ~]# echo "welcome to the blog of Bash" welcome to the blog of Bash 只需要使用带双引号的文本,结合echo命令就可以将该文本在终端中打印出来
但是在写shell脚本的时候,需要考虑兼容性, 最主流的还是bash shell,所以,后文我们介绍的shell脚本也是bash shell的。 4、shell脚本 4.1、基础 #!...#上面已经提高过,单引号里面的变量是不会解析的 ? 强大的字符串处理 shell中简单的处理字符串,可以直接使用各种标记,只是比较难记忆,要用的时候,可以查一下。...%-4.2f 指格式化为小数,其中.2指保留2位小数。 4.5.4、重定向 大多数 UNIX 系统命令从你的终端接受输入并将所产生的输出发送回到您的终端。...有几个符号要非常注意,用的也比较多,不要搞混了,搞混了,逻辑运算很容易出错 4.7.1、单小括号() 命令组 括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用。...后台运行的最后一个进程的ID号 $@ 与$*相同,但是使用时加引号,并在引号中返回每个参数。$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
接下来,我们将带领大家深入探讨如何在MySQL、PostgreSQL、Redis及MySQL 8这四种流行数据库中实现地理空间查询优化和地理数据分析。...在这个全面的GIS技术指南中,我们将一起揭开数据背后的世界,发现地理空间查询在大数据分析中的无限可能!我们将探讨如何有效存储地理空间数据,实现高效的地理空间数据查询,以及如何进行精准的空间数据分析。...PostgreSQL & PostGIS:专业的地理空间数据处理 2.1 创建表格和数据插入 在 PostgreSQL 中,我们将使用 PostGIS 扩展来存储和操作地理空间数据。...总结 在这一探索性的知识之旅中,我们深入挖掘了四种流行数据库——MySQL, PostgreSQL, Redis, 以及 MySQL 8——在地理空间查询领域的应用与实现。...接下来,我们研究了 PostgreSQL 配合 PostGIS 扩展的应用,这使得我们不仅能执行基础查询,还能进行更复杂的空间分析和计算。
#,shell编程 简介 Unix/Linux上常见的Shell脚本解释器有bash、sh、csh、ksh等,习惯上把它们称作一种Shell。...双引号可有可无,单引号主要用在原样输出中。 printf:格式化输出语句。 printf 命令用于格式化输出, 是echo命令的增强版。...单双引号的区别跟PHP类似: * 双引号里可以有变量,单引号则原样输出; * 双引号里可以出现转义字符,单引号则原样输出; * 单引号字串中不能出现单引号。 1....索引是从0开始的。 expr substr "$str" 1 6 分别输出: 3 3 4 10 i love 注意字符串变量需要加双引号。...cal 2020 >> cal.txt 获取当前正在执行脚本的绝对路径 正确的命令是: bash basepath=(cd dirname 0; pwd) 直接使用pwd或者dirname
领取专属 10元无门槛券
手把手带您无忧上云