首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

shell获取当前工作目录绝对路径

一般我们写Shell脚本的时候,都倾向使用绝对路径,这样无论脚本在什么目录执行,都应该起到相同的效果,但是有些时候,我们设计一个软件包中的工具脚本或者远程调用某个脚本时,可能使用相对路径更加灵活一点,因为你不知道用户会在哪个目录执行你的程序...常见的一种误区,是使用 pwd 命令,该命令的作用是“print name of current/working directory”,这才是此命令的真实含义,当前的工作目录,这里没有任何意思说明,这个目录就是脚本存放的目录...fi  fi  echo $this_dir 总结一下其实就是一条命令: base_dir=$(cd "$(dirname "$0")";pwd) dirname  $0 ,取得当前执行的脚本文件的父目录...cd  dirname $0 ,进入这个目录(切换当前工作目录) pwd,显示当前工作目录(cd执行后的) 我今天遇到一个问题就是: 需要压缩备份一个目录下的所有的文件,其实代码就2行: 我还是贴全部的吧

11.6K70

shell 当前工作目录的绝对路径

/something ${work_path} 问题就出在最后那句,本意我是希望把/home/lcd/something 复制到我脚本的执行目录。...假设我的脚本目录在/home/lcd/shell/下, bash /home/lcd/shell/mytest.sh # work_path -> home/lcd/shell # 能得到想要的 lcd.../mytest.sh # work_path -> ./ # 所以上面的执行方式,something 还是复制到了./ # 也就是最后 cd 进去的目录下 查了下,总结下获取路径的方法,以及可能的误区。...看看下面这些获取路径的方法 # 在某些情况下会拿到错误结果 work_path=$(dirname $0) work_path=$(pwd) ## 正确实现 # 通过 readlink 获取绝对路径,再取出目录.../${work_path} # 当前位置跳到脚本位置 work_path=$(pwd) # 取到脚本目录

2.9K41

MySQL源码目录

MySQL源码目录 今天一天没怎么干正事儿,就简单聊聊mysql源码目录中每个文件夹里面的内容吧,因为回家比较早,所以就在笔记本的window平台下截了一张mysql源码的目录图,如下: ?...下面简单说说这些目录中比较重要的文件夹: Build: 该目录包含了各个平台,各种编译器下进行编译的脚本。...mysql-test: mysqld的测试小工具 mysys: mysql自己实现的一些常用数据结构和算法。...regex: 一些关于正则表达式的算法实现 scripts: 包含一些系统工具脚本,比如mysql_installed_db、mysqld_safe等 sql: mysql服务器的主要代码,包含了...main函数,会生成mysqld可执行文件 sql_common: 存放部分服务器端和客户端都会用到的一些代码 storage: 所有存储引擎的源代码都在这个目录中。

3K21

【linux命令讲解大全】107.pwd 命令:显示当前工作目录的绝对路径

pwd 显示当前工作目录的绝对路径。 补充说明 pwd(英文全拼:print working directory)命令用于显示用户当前所在的工作目录(以绝对路径显示)。...-P: 打印当前工作目录的物理位置。 返回值 返回状态为成功除非给出了非法选项或是当前目录无法读取。 注意 该命令是bash内建命令,相关的帮助信息请查看help命令。...主要用途 显示当前工作目录。 选项 -L, --logical: 打印环境变量$PWD的值,可能为符号链接。 -P, --physical(默认值): 打印当前工作目录的物理位置。...返回值 返回状态为成功除非给出了非法选项或是当前目录无法读取。...mail -> spool/mail [root@localhost var]# cd mail/ # 进入 mail 目录,mail 为连接文件。

43010

Linux 系统中查找正在运行的进程的完整命令、当前工作目录等信息的方法

Linux 系统中查找正在运行的进程的完整命令、当前工作目录等信息的方法 一 引言 在某些系统故障的排查过程中,需要找出某个应用程序的工作目录、完整命令行等信息。...按照这样的思路,通过/proc目录下面的相关信息查找到对应的蛛丝马迹。Linux在启动一个进程时,系统会在/proc下创建一个以进行PID命名的目录,在该目录下保存着该进程的各种信息。...针对一些常见的内容及要点,收集整理如下: cmdline:启动当前进程的完整命令,但僵尸进程目录中的此文件不包含任何信息; cwd:指向当前进程运行目录的一个符号链接; environ:当前进程的环境变量列表...彼此间用空字符(NULL)隔开;变量用大写字母表示,其值用小写字母表示; exe:指向启动当前进程的可执行文件(完整路径)的符号链接,通过/proc/PID/exe可以启动当前进程的一个拷贝; fd:这是个目录...,每个线程的相关信息文件均保存在一个由线程号(tid)命名的目录中,这类似于其内容类似于每个进程目录中的内容(内核2.6版本以后支持此功能) 三 操作细节 以 dockerd 进程为例。

1.8K20

KangLe 把mysql数据库目录移动到home目录

KangLe 把mysql数据库目录移动到/home目录使其更安全,重装系统也不怕丢数据    kangle ep面板是采用的yum安装的mysql,mysql数据库目录位置在/var/lib/mysql...,那么我们现在移动至/home/mysqldata目录(如果你的vps构架是ovz就不需要了,就是没有数据盘),注意先初始化好mysql,也就是说一定要在kangleep面板里把mysql的root密码设置好...mysql service mysqld stop(注意如果是mysql5.1或5.5使用service mysql stop) 移动到/home/mysqldata目录 mv /var/lib/mysql.../home/mysqldata 创建软连 ln -s /home/mysqldata /var/lib/mysql 编辑mysql配置my.cnf文件 vi /etc/my.cnf 修改下面的项目.../mysqld.log pid-file=/home/mysqldata/mysqld.pid 保存退出 重启mysql service mysqld start

2.3K30

MySQL 移动数据目录后启动失败

MySQL 移动数据目录后启动失败 背景概述 由于安装数据库时将MySQL的数据目录放在了根目录下,现在存储空间不足,想通过mv将数据目录移动到其他目录下,但将数据目录移动到其他数据目录后,启动数据库失败...问题复现 本次测试基于 MySQL 8.0.31 1.关闭数据库 mysql> shutdown; Query OK, 0 rows affected (0.02 sec) 2.查看当前数据目录所在位置...shell> pwd /mysql80 3.通过mv移动整个MySQL数据目录到其他目录 shell> mv /mysql80 /data shell> cd /data/mysql80/svr...5.修改配置文件中数据目录的地址 shell> sed -i 's#/mysql80#/data/mysql80#g' my5001.cnf 6.启动数据库 shell> /data/mysql80...这里报错显示找不到binlog文件,并且报错显示的binlog的目录还是之前的,但是配置文件中的目录已经修改 shell> grep 'log-bin' my5001.cnf log-bin=/data

30820

如何使用Symlink更改MySQL数据目录

无论您是要添加更多空间,评估优化性能的方法,还是希望利用其他存储功能,本教程都将指导您重新定位MySQL的数据目录。 此处的说明适用于运行单个MySQL实例的服务器。...第一步,移动MySQL数据目录 为确保数据的完整性,我们将关闭MySQL: $ sudo systemctl stop mysql 由于systemctl不显示所有服务管理命令的结果,因此如果您想确定已成功...关闭服务器后,我们会将现有数据库目录移动到新位置: $ sudo mv /var/lib/mysql /mnt/volume-nyc1-01/mysql 接下来,我们将创建Symlink: $ sudo...第二步,配置AppArmor访问控制规则 将MySQL目录移动到与MySQL服务器不同的文件系统时,您需要创建AppArmor别名。...虽然我们使用的是块存储设备,但此处的说明适用于重新定义数据目录的位置,而不管底层技术如何。但是这种方法仅适用于运行MySQL的单个实例。

3.6K60

centos7修改mysql数据存储目录

随着数据量的增长,mysql数据所占的空间会越来越大,而默认情况下mysql数据盘空间可能不够,这时候,就需要修改存储路径 ?...image 网上有很多修改路径的方式,需要改配置文件,比较麻烦,在目标路径建好目录,再建个软连接就可以了,不需要改动任何配置 查看mysql数据存储位置: mysql> show global variables...,如 killall mysqld 新建存储目录,如: mkdir -p /data/mysql 将原数据盘拷贝 $ cd /usr/local/mysql $ cp -r var /data/mysql...$ mv var var_copy # 避免操作失误,留个备份 $ ln -s /data/mysql/var . # 建立软链 $ # 修改权限 $ sudo chown -R mysql:mysql.../data/mysql $ sudo chown -R mysql:mysql var 重启mysql服务,便大功告成

2.1K00
领券