2024-08-23

在Linux系统中,软件源配置主要是通过修改 /etc/apt/sources.list 文件以及添加相关的源列表文件来实现的。下面是一个基本的示例:

  1. 打开终端。
  2. 使用文本编辑器打开 /etc/apt/sources.list 文件,例如使用 nanovim



sudo nano /etc/apt/sources.list

或者




sudo vim /etc/apt/sources.list
  1. 添加或修改文件中的软件源地址,例如添加官方的 Ubuntu 软件源:



deb http://archive.ubuntu.com/ubuntu/ focal main restricted
deb http://archive.ubuntu.com/ubuntu/ focal-updates main restricted
deb http://archive.ubuntu.com/ubuntu/ focal universe
deb http://archive.ubuntu.com/ubuntu/ focal-updates universe
deb http://archive.ubuntu.com/ubuntu/ focal multiverse
deb http://archive.ubuntu.com/ubuntu/ focal-updates multiverse
deb http://archive.ubuntu.com/ubuntu/ focal-backports main restricted universe multiverse
deb http://security.ubuntu.com/ubuntu focal-security main restricted
deb http://security.ubuntu.com/ubuntu focal-security universe
deb http://security.ubuntu.com/ubuntu focal-security multiverse
  1. 保存并关闭文件。
  2. 更新软件包列表:



sudo apt update
  1. 如果需要的话,升级所有安装的包:



sudo apt upgrade

请根据您使用的Linux发行版和地理位置选择合适的软件源。对于其他发行版(如Red Hat/CentOS),软件源配置文件的位置和格式可能会有所不同。

2024-08-23

在Linux下配置Redis和使用Redis命令,你需要完成以下步骤:

  1. 安装Redis:



sudo apt update
sudo apt install redis-server
  1. 启动Redis服务:



sudo systemctl start redis-server
  1. 确认Redis正在运行:



sudo systemctl status redis-server
  1. 配置Redis(可选):

    编辑Redis配置文件 /etc/redis/redis.conf,可以使用文本编辑器,如 nanovim

  2. 使用Redis命令:
  • 进入Redis CLI:



redis-cli
  • 在Redis CLI内执行Redis命令,例如:



SET key "value"
GET key
  1. 退出Redis CLI:



quit

Redis 提供了全局命令,例如:

  • PING:检查Redis服务器是否运行。
  • SELECT:切换到不同的数据库。
  • CONFIG GET:获取配置参数的值。
  • INFO:获取Redis服务器的各种信息和统计。
  • SAVEBGSAVE:将数据同步保存到硬盘。
  • SHUTDOWN:关闭Redis服务器。

这些命令可以在redis-cli中直接使用,例如:




redis-cli
PING

如果你需要更详细的命令列表和使用示例,可以查看Redis官方文档或使用 redis-cli 命令后跟 help 查看可用命令和语法帮助。

2024-08-23

TCP协议为了管理通信连接,定义了一系列的状态转换图,这些状态转换图描绘了TCP连接从开始到结束的生命周期中所经历的各种状态。以下是TCP连接状态转换图的核心部分:




                                   +----------+
                                   |  CLOSED  |
                                   +----------+
                                      |     ^
                                      v     |
                                   +----------+
                                   |  LISTEN  |
                                   +----------+
                                      |     ^
                                      v     |
                                   +----------+
                                   |  SYN_RCVD|
                                   +----------+
                                      |     ^
                                      v     |
                 +------------------+-----------+
                 |                  |           |
                 v                  v           v
           +----------+          +----------+    +----------+
           |  SYN_SENT|          | SYN_SENT|    |  CLOSED  |
           +----------+          +----------+    +----------+
                |                    |               |     ^
                v                    v               v     |
         +---------------+          +---------------+      |
         |     ESTAB     |          |     ESTAB     |      |
         |               |          |               |      |
         |               |          |               |      |
         +---------------+          +---------------+      |
                |                    |               |      |
                v                    v               v      |
         +---------------+          +---------------+      |
         |    FIN_WAIT1  |          |    FIN_WAIT2  |      |
         +---------------+          +---------------+      |
                |                    |               |      |
     
2024-08-23



# 启动 firewalld
sudo systemctl start firewalld
 
# 设置 firewalld 开机自启
sudo systemctl enable firewalld
 
# 查看 firewalld 状态
sudo systemctl status firewalld
 
# 停止 firewalld
sudo systemctl stop firewalld
 
# 重新加载 firewalld 配置
sudo firewall-cmd --reload
 
# 查看所有打开的端口
sudo firewall-cmd --list-ports
 
# 开放指定端口
sudo firewall-cmd --permanent --add-port=8080/tcp
 
# 移除指定端口
sudo firewall-cmd --permanent --remove-port=8080/tcp
 
# 允许特定服务
sudo firewall-cmd --permanent --add-service=http
 
# 禁止特定服务
sudo firewall-cmd --permanent --remove-service=http
 
# 允许某个 IP 访问
sudo firewall-cmd --permanent --add-source=192.168.1.100
 
# 禁止某个 IP 访问
sudo firewall-cmd --permanent --remove-source=192.168.1.100
 
# 允许某个 IP 范围访问
sudo firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.0/24" accept'
 
# 禁止某个 IP 范围访问
sudo firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.0/24" reject'

这些命令提供了基本的 firewalld 操作,包括启动、停止、重载、开放端口、允许或拒绝服务和 IP 地址。使用 --permanent 标志可以使规则在防火墙重启后依然有效。

2024-08-23

Stirling-PDF是一个用于将HTML转换成PDF格式的服务。以下是使用Docker部署Stirling-PDF服务的步骤:

  1. 确保你的系统上安装了Docker。
  2. 从Docker Hub拉取Stirling-PDF的Docker镜像:



docker pull gutenex/stirling-pdf
  1. 运行Stirling-PDF容器:



docker run -d --name stirling-pdf -p 8080:8080 gutenex/stirling-pdf

这条命令将会启动一个名为stirling-pdf的容器,并将容器的8080端口映射到宿主机的8080端口上。

  1. 现在你可以使用任何支持PDF生成的应用程序或服务来远程处理本地文档了。你可以使用如Postman、Curl或任何支持HTTP请求的编程语言来发送HTTP请求到http://localhost:8080

以下是一个使用curl发送转换请求的例子:




curl -X POST "http://localhost:8080/convert" -H "Content-Type: application/json" -d "{\"html\":\"<html><body><h1>Hello, World!</h1></body></html>\"}"

这将会发送一个将HTML字符串转换为PDF的请求,并且如果转换成功,Stirling-PDF服务将会返回一个PDF文件的字节流。

2024-08-23

在Linux中,进程的创建通常使用fork()系统调用。fork()会创建一个与父进程几乎完全相同的子进程副本。子进程会从fork()调用的下一行代码处开始执行。




#include <stdio.h>
#include <unistd.h>
 
int main() {
    pid_t pid = fork();
 
    if (pid == -1) {
        // 错误处理
        perror("fork failed");
        return 1;
    } else if (pid == 0) {
        // 子进程中的分支
        printf("子进程正在运行,PID: %d\n", getpid());
    } else {
        // 父进程中的分支
        printf("父进程正在运行,创建的子进程PID: %d\n", pid);
    }
 
    // 确保父进程或子进程中的代码不会继续执行
    return 0;
}

进程终止可以使用exit()_exit系统调用。exit()会先刷新缓冲区,然后关闭所有打开的流,而_exit()会直接终止进程而不执行任何清理工作。




#include <stdio.h>
#include <stdlib.h>
 
int main() {
    printf("进程即将终止\n");
    exit(EXIT_SUCCESS); // 正常终止
    // _exit(0); // 也可以使用_exit来终止进程
}

在Linux中,slab分配器是一种内存分配机制,用于分配小型对象,以减少外部碎片和提高内存的使用效率。slab分配器通常不直接由应用程序代码调用,而是由Linux内核或一些底层库在后台使用。如果你需要调试或检查slab分配器的状态,可以使用/proc/slabinfo文件或通过slabtop命令来查看。




cat /proc/slabinfo
slabtop

以上命令可以在终端中执行,以查看当前的slab分配器的状态和分配信息。

2024-08-23

在Linux系统中,top命令是一个用来显示系统进程状态的实用工具,它可以显示CPU使用率,内存使用情况,正在运行的进程等信息。

  1. 使用top命令查看CPU使用率



top
  1. 使用top命令查看特定线程的CPU使用率

首先,你需要知道你想要查看的线程的PID。你可以使用ps命令或者top命令来找到你想要的线程的PID。




ps -ef | grep thread_name

或者




top | grep thread_name

然后,你可以使用top命令并指定PID来查看特定线程的CPU使用率。




top -p PID
  1. 使用top命令定制显示信息

top命令有许多交互式命令,可以定制显示信息。例如,你可以使用Shift + P按CPU使用率排序进程,或者使用Shift + M按内存使用率排序进程。




top

然后按Shift + P或Shift + M进行排序。

  1. 使用top命令定时刷新

你可以使用-d选项来设置刷新间隔,单位是秒。




top -d 5

这个命令每5秒刷新一次。

  1. 使用top命令保存输出到文件

你可以使用-b选项和-n选项来将top的输出保存到文件。




top -b -n 10 > output.txt

这个命令将top的输出保存到output.txt文件中,一共保存10次。

  1. 使用top命令查看特定用户的进程

你可以使用-u选项来查看特定用户的进程。




top -u username

这个命令将只显示用户名为username的用户的进程。

  1. 使用top命令结束进程

在top命令中,你可以按k键结束进程。当你按下k键,然后输入要结束的进程PID,最后按回车,就可以结束该进程。




top

然后按k键,输入PID,回车。

以上就是top命令的一些常见用法,你可以根据你的需求来使用这些命令。

2024-08-23

在Linux中,可以通过多种方式查看和获取环境变量。以下是四种常用方法:

  1. 使用echo$变量名显示特定环境变量。
  2. 使用env命令显示所有环境变量。
  3. 使用printenv命令显示所有环境变量(env的别名)。
  4. 使用C语言标准库函数getenv获取特定环境变量的值。

方法1: 使用echo$变量名显示特定环境变量




echo $PATH

方法2: 使用env命令显示所有环境变量




env

方法3: 使用printenv命令显示所有环境变量




printenv

方法4: 使用C语言标准库函数getenv获取特定环境变量的值




#include <stdio.h>
#include <stdlib.h>
 
int main() {
    char* path = getenv("PATH");
    if (path) {
        printf("PATH: %s\n", path);
    } else {
        printf("PATH is not set\n");
    }
    return 0;
}

这段C代码会打印出PATH环境变量的值。需要注意的是,getenv函数是区分大小写的。

2024-08-23

在 Linux 命令行中检查 CPU 使用率,可以使用 tophtop(如果安装了)或者 mpstat 命令。以下是这些命令的简单示例:

  1. 使用 top 命令:



top

然后按 1 显示各个CPU的使用率。

  1. 使用 htop 命令(如果安装了):



htop

htop 提供了一个更加直观的界面来查看CPU使用情况。

  1. 使用 mpstat 命令(如果安装了 sysstat 包):



mpstat -P ALL 1

这将显示所有CPU的实时使用率,每隔1秒更新一次。

如果你只想快速查看所有CPU的使用率,可以使用 awk 来解析 top 的输出:




top -bn1 | grep "Cpu(s)" | awk '{print $2 + $4 + $6}'

这条命令将显示总的CPU使用率百分比,其中 top -bn1 运行一次顶部报告,grep "Cpu(s)" 过滤出包含“Cpu(s)”的行,awk 将用户、系统和空闲时间相加并打印出来。

2024-08-23

在Linux系统中,当一个父进程创建了一个子进程,并且子进程结束了,但是父进程没有通过调用wait()或者waitpid()系统调用来获取子进程的状态,那么子进程的进程描述符就会保留在系统中,这样的子进程称为僵尸进程(Zombie Process)。僵尸进程会占用进程表中的一个位置,如果有大量的僵尸进程积累,最终可能导致进程表满,进而导致无法创建新的进程。

解决方法:

  1. 通过信号机制:父进程可以通过设置信号处理函数,当子进程结束时,父进程会收到SIGCHLD信号,然后在信号处理函数中调用wait()waitpid()来清理子进程。
  2. 使用waitpid()函数的WNOHANG选项:父进程可以通过定期调用waitpid()并传递WNOHANG选项来检查是否有已经结束的子进程需要清理,如果没有结束的子进程,则该调用会立即返回,不会阻塞父进程。
  3. 系统级别的解决方案:可以通过设置父进程的SIGCHLD信号处理为SIG_IGN,这样内核会自动清理僵尸进程。

示例代码:




#include <stdio.h>
#include <stdlib.h>
#include <sys/wait.h>
#include <signal.h>
 
void reap_child(int sig) {
    wait(NULL); // 清理僵尸进程
}
 
int main() {
    pid_t pid;
 
    // 安装信号处理函数
    struct sigaction sa;
    sa.sa_handler = &reap_child;
    sigemptyset(&sa.sa_mask);
    sa.sa_flags = 0;
    sigaction(SIGCHLD, &sa, NULL);
 
    // 创建子进程
    pid = fork();
    if (pid == -1) {
        perror("fork failed");
        exit(EXIT_FAILURE);
    }
 
    if (pid > 0) {
        // 父进程
        printf("Parent process, PID: %d\n", getpid());
    } else {
        // 子进程
        printf("Child process, PID: %d\n", getpid());
        sleep(5); // 模拟子进程运行
        exit(EXIT_SUCCESS); // 子进程结束
    }
 
    return 0;
}

在这个示例中,父进程安装了一个信号处理函数reap_child,当接收到SIGCHLD信号时,会在信号处理函数中调用wait()来清理僵尸进程。这样就可以避免子进程成为僵尸进程所带来的问题。