Linux实战笔记(五) shell
大家好,我是半虹,这篇文章我们介绍一下 shell
1、Shell
Shell 通常泛指系统提供给用户的操作界面,是系统内核与用户之间的连接
Shell 这个名字其实还挺形象的,中文翻译是壳,什么的壳呢,自然是系统内核的壳
操作界面可以分为两种,分别是命令行接口 (CLI) 和图形用户接口 (GUI)
现在一般说的 Shell 通常都是指命令行接口,也可以理解成是终端
在 Linux 上的 Shell 种类很多,下面来介绍一些常见的:
- Bourne Shell (sh):Unix 系统中最早的 Shell 之一 ,功能较为基础,用户交互较弱
- Bourne Again Shell (bash):sh 的拓展,提供更多新特性,是大多数 Linux 默认的 Shell
- Z Shell (zsh):功能更强大但配置较复杂,搭配
oh-my-zsh还是非常推荐的
下面这些命令可以用来查看和修改用户 Shell:
- 查看所有可用 Shell
cat /etc/shells# /bin/sh
# /bin/bash
# /bin/dash
- 查看默认登录 Shell
cat /etc/passwd# root:x:0:0:root:/root:/bin/bash
# ...
# ...
# 输出信息以 : 为分割,其中第一项为用户名,最后一项为该用户的默认登录 Shell
- 修改默认登录 Shell
chsh# Password:
# Changing the login shell for <当前用户>
# Enter the new value, or press ENTER for the default
# Login Shell [/bin/bash]:
2、配置文件
不同的 Shell 会有不同的配置文件,这些配置文件可以用来设置环境变量、定义别名等等
下面以 Ubuntu 18.04.6 系统下的 Bash 为例进行介绍:
| 文件路径 | 影响范围 | 一般作用 | 执行时机 | 修改后如何生效 |
|---|---|---|---|---|
/etc/profile | 所有用户 | 完成系统级初始化任务 | 用户登陆 | 使用 source,或重新登录 |
/etc/bash.bashrc | 所有用户 | 设置系统级自定义终端 | 打开终端 | 使用 source,或新开终端 |
~/.profile | 当前用户 | 完成用户级初始化任务 | 用户登陆 | 使用 source,或重新登录 |
~/.bashrc | 当前用户 | 设置用户级自定义终端 | 打开终端 | 使用 source,或新开终端 |
这四个配置文件有着密切关联,下面会从 login shell 和 non-login shell 的角度切入分析
login shell 意味着需要通过密码登录进入 shell,反之,non-login shell 则无需重复登录
无论我们通过图形化界面,还是通过命令行界面登录 shell ,这些都属于 login shell
而在登录后的图形化界面打开终端,或者通过 su 切换用户,这些则属于 non-login shell
login shell 配置文件读取流程如下:
-
login 进程调用/etc/profile,/etc/profile调用/etc/bash.bashrc# /etc/profile # 包含调用 /etc/bash.bashrc 的关键代码if [ "${PS1-}" ]; thenif [ "${BASH-}" ] && [ "$BASH" != "/bin/sh" ]; then# The file bash.bashrc already sets the default PS1.# PS1='\h:\w\$ 'if [ -f /etc/bash.bashrc ]; then. /etc/bash.bashrc # 调用 /etc/bash.bashrc【关键代码】fielseif [ "`id -u`" -eq 0 ]; thenPS1='# 'elsePS1='$ 'fifi fiif [ -d /etc/profile.d ]; thenfor i in /etc/profile.d/*.sh; doif [ -r $i ]; then. $i # 调用 /etc/profile.d/ 下的所有脚本fidoneunset i fi -
login 进程调用~/.profile,~/.profile调用~/.bashrc# ~/.profile # 包含调用 ~/.bashrc 的关键代码# if running bash if [ -n "$BASH_VERSION" ]; then# include .bashrc if it existsif [ -f "$HOME/.bashrc" ]; then. "$HOME/.bashrc" # 调用 ~/.bashrc【关键代码】fi fi# set PATH so it includes user's private bin if it exists if [ -d "$HOME/bin" ] ; thenPATH="$HOME/bin:$PATH" # 设置环境变量 fi# set PATH so it includes user's private bin if it exists if [ -d "$HOME/.local/bin" ] ; thenPATH="$HOME/.local/bin:$PATH" # 设置环境变量 fi
non-login shell 配置文件读取流程如下:
non-login 进程调用/etc/bash.bashrcnon-login 进程调用~/.bashrc
关于 non-login shell 配置文件的读取,其实还有些微妙现在网上大多数博客的写法是 non-login shell 只会读取 ~/.bashrc但是经过测试后发现,/etc/bash.bashrc 也会被执行当然还有一部分博客,包括 ChatGPT 都说是因为 ~/.bashrc 调用的 /etc/bash.bashrc但是经过测试后发现,/etc/bash.bashrc 是在 ~/.bashrc 之前被执行的,这就不可能是调用了---怎么测试的呢,也比较简单在 /etc/bash.bashrc 文件可执行的第一行和最后一行分别加上:
echo "-> /etc/bash.bashrc start"
echo "-> /etc/bash.bashrc end"在 ~/.bashrc 文件可执行的第一行和最后一行分别加上:
echo "-> ~/.bashrc start"
echo "-> ~/.bashrc end"然后登录 root 用户,再用 su username 切换回设置的用户,输出顺序如下:
-> /etc/bash.bashrc start
-> /etc/bash.bashrc end
-> ~/.bashrc start
-> ~/.bashrc end---现在可以确定的一点是,至少在 Ubuntu 18.04.6 系统下,non-login shell 会执行 /etc/bash.bashrc 和 ~/.bashrc但是其中具体的细节目前还不是很清楚,如果有朋友对这块比较了解,还请不吝赐教!
说到这里,或许你就能理解为啥有时候使用 su 切换用户后,某些环境变量没有生效
因为这时候登录的是 non-login shell,不会执行 /etc/profile 以及 ~/.profile
如果有一些环境变量写在这两个文件,文件没有被执行,那么自然也就没有进行设置
其实, su 是能够以 login shell 的方式切换用户的
只需要加上 -l 参数即可,例如 su -l username
这时候就能读取完整配置,正确设置所有环境变量,这是一个常常被大家忽视的技巧
3、环境变量
在使用 Shell 的时候,一个最常见的需求就是为各种软件去设置环境变量
环境变量有很多,下面分类介绍下:
- 配置系统信息,例如
PATH:指定可执行文件的搜索路径LANG:设置默认语言环境
- 定义用户环境,例如
PS1:定制命令行提示符HOME:指定用户的主目录
- 控制应用行为,例如
- 以
NVM_开头的变量:定义 nvm 相关信息 - 以
CONDA_开头的变量:定义 conda 相关信息
- 以
一般来说,安装软件的时候会自动配置环境变量,如果没有,那就需要我们手动配置
下面就以配置可执行文件的搜索路径 PATH 为例来进行讲解,通常有两种不同的方式
- 临时生效:在当前终端配置,在当前终端生效
- 永久生效:在配置文件配置,对所有终端有效
(1)临时生效
查看所有环境变量:
env
输出指定环境变量:
echo $PATH
设置临时环境变量:
export PATH=$PATH:/new/path # 注意这里赋值 PATH 时,需要拼接上原来 PATH 的值
(2)永久生效
因为每次登录或者打开终端都会执行配置文件,所以写在其中的命令对所有终端生效
这样就能避免对每一个终端都要手动进行设置,达到永久有效的目的
对于用户级配置,一般都会写在 ~/.bashrc ,具体设置的步骤如下:
- 打开配置文件
vi ~/.bashrc
- 在文件的最后写入配置命令,保存并关闭文件
export PATH=$PATH:/new/path
- 激活配置文件
source ~/.bashrc
好啦,本文到此结束,感谢您的阅读!
如果你觉得这篇文章有需要修改完善的地方,欢迎在评论区留下你宝贵的意见或者建议
如果你觉得这篇文章还不错的话,欢迎点赞、收藏、关注,你的支持是对我最大的鼓励 (/ω\)
相关文章:
Linux实战笔记(五) shell
大家好,我是半虹,这篇文章我们介绍一下 shell 1、Shell Shell 通常泛指系统提供给用户的操作界面,是系统内核与用户之间的连接 Shell 这个名字其实还挺形象的,中文翻译是壳,什么的壳呢,自然是系统内核的壳…...
TCP Wrappers 的使用
以ssh为例,每当有ssh的连接请求时,先读取系统管理员所设置的访问控制文件,符合要求,则会把这次连接原封不 动的转给ssh进程,由ssh完成后续工作;如果这次连接发起的ip不符合访问控制文件中的设置,…...
数据结构——lesson11排序之快速排序
💞💞 前言 hello hello~ ,这里是大耳朵土土垚~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹 💥个人主页&#x…...
Nacos部署(二)Linux部署Nacos2.3.x集群环境
😊 作者: 一恍过去 💖 主页: https://blog.csdn.net/zhuocailing3390 🎊 社区: Java技术栈交流 🎉 主题: Nacos部署(二)Linux部署Nacos2.3.x集群环境 ⏱️…...
RuoYi 自定义字典列表页面编码翻译
“字典数据”单独维护,而不是使用系统自带的字典表,应该如何使用这样的字典信息呢? 系统字典的使用,请参考: 《RuoYi列表页面字典翻译的实现》 https://blog.csdn.net/lxyoucan/article/details/136877238 需求说明…...
GAMES101 学习4
材质和外观 材质 BRDF 漫反射 任何方向的光进来都会被均匀的反射到周围各个不同的方向上去 假设能量守恒,那么 Li Lo,这之后BRDF就 ,就可以定义一个反照率 (Albeo) - ,在(0 - 1࿰…...
Redis中的缓存穿透
缓存穿透 缓存穿透是指客户端请求的数据在缓存中和数据库中都不存在,导致这些请求直接到了数据库上,对数据库造成了巨大的压力,可能造成数据库宕机。 常见的解决方案: 1)缓存无效 key 如果缓存和数据库中都查不到某…...
javaSwing超市收银(txt)
一、简介 超市收银系统是商店管理的重要组成部分,它可以帮助商家高效地进行商品管理、销售记录和结算。本文将介绍如何使用Java Swing开发一个简单的超市收银系统,包括基本功能如登录、修改商品信息、结算等,并利用txt文本作为数据库存储商品…...
Linux 理解文件系统、磁盘结构、软硬链接
目录 一、理解磁盘结构 1、磁盘的物理结构 2、硬件层面理解 3、磁盘的具体物理存储结构 4、进行逻辑抽象 5、磁盘文件的管理 6、创建新文件的过程 二、理解文件系统 1、文件的构成 2、为何选择4KB而非512字节作为基本单位? 3、文件系统的组成 数据块(Data Blocks&a…...
智慧商场数字化创新需要有数字能力帮手
商场和商圈是是促进流通创新、培育新兴消费的载体。很多实体店为适应消费升级需求新变化,加快运用现代信息技术,建设智慧商店,创新消费场景。蚓链运用现代信息技术(互联网、物联网、5G、大数据、人工智能、云计算等)&a…...
JS加密解密之应用如何保存到桌面书签
前言 事情起因是这样的,有个客户解密了一个js,然后又看不懂里边的一些逻辑,想知道它是如何自动拉起谷歌浏览器和如何保存应用到书签的,以及如何下载应用的。继而诞生了这篇文章,讲解一下他的基本原理。 渐进式Web应用…...
线上linux服务器升级nginx
一个nginx版本空包 一个pcre文件 一个zlib文件 ./configure配置文件 make编译 make install复制所有文件到nginx 如果nginx -v无版本号 检查环境变量cat /etc/profile 编辑 环境变量vi /etc/profile 按i进入编辑模式 按esc进入查看模式 因为path中并未使用%JAVA_HOME%字样…...
使用JDK提供的常用工具在多线程编写线程安全和数据同步的程序
题图来自APOD 你好,这里是codetrend专栏“高并发编程基础”。 引言 在并发执行任务时,由于资源共享的存在,线程安全成为一个需要考虑的问题。与串行化程序相比,并发执行可以更好地利用CPU计算能力,提高系统的吞吐量…...
八道Python入门级题目及答案详解
前言 介绍Python作为一门流行的编程语言,易学易用的特点。强调通过练习题目来加深对Python语法和编程概念的理解。 题目一:计算两个数的和 描述:编写一个Python程序,计算两个数的和,并输出结果。举例:输…...
Git 的cherry-pick含义
目录 1. cherry-pick的基本概念 2. cherry-pick的使用场景 3. cherry-pick的使用方法 结论 1. cherry-pick的基本概念 git cherry-pick是一个Git命令,它允许你选择一个或多个其他分支上的提交(commits),并将它们复制到你当前的…...
大数据中TopK问题
1.给定100个int数字,在其中找出最大的10个; import java.util.PriorityQueue;public class Main {public static void main(String[] args) {final int topK 3;int[] vec {4, 1, 5, 8, 7, 2, 3, 0, 6, 9};PriorityQueue<Integer> pq new PriorityQueue<…...
基于SpringBoot+MyBatis+Vue的电商智慧仓储管理系统的设计与实现(源码+LW+部署+讲解)
前言 博主简介👨🏼⚕️:国内某一线互联网公司全栈工程师👨🏼💻,业余自媒体创作者💻,CSDN博客专家🏆,Java领域优质创作者📕&#x…...
C++经典面试题目(四)
1、请解释const关键字的作用。 在C中,const关键字主要用来表示“不变性”,即被它修饰的东西是不可修改的。它可以用于多种上下文: 修饰基本数据类型变量:声明一个常量,一旦初始化后,其值就不能再更改。 co…...
2024/3/24 蓝桥杯
P1678 烦恼的高考志愿 二分 import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int m sc.nextInt();int[] a new int[n1];//学校int[] b new int[m…...
用户验证:Streamlit应用程序与Streamlit-Authenticator
写在前面 在数字化时代,数据安全和用户隐私越来越受到重视。对于使用Streamlit构建的Web应用程序来说,确保用户的安全身份验证是至关重要的。而Streamlit-Authenticator,作为一个专门为Streamlit应用程序设计的身份验证库,正成为保…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...
【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
Linux简单的操作
ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...
从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
c#开发AI模型对话
AI模型 前面已经介绍了一般AI模型本地部署,直接调用现成的模型数据。这里主要讲述讲接口集成到我们自己的程序中使用方式。 微软提供了ML.NET来开发和使用AI模型,但是目前国内可能使用不多,至少实践例子很少看见。开发训练模型就不介绍了&am…...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
Python Ovito统计金刚石结构数量
大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...
使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
