2024-08-10

在Linux环境中,Shell脚本是一种常用的自动化工具。下面是一些Shell脚本中常用的工具和代码示例:

  1. grep:搜索文件内容。



grep "error" logfile.log
  1. find:在文件系统中查找文件。



find /home -name "*.txt"
  1. awk:处理文本文件中的数据。



awk '{print $1,$3}' logfile.log
  1. sed:流编辑器,用于处理文本数据。



sed 's/old/new/' file.txt
  1. sort:对文件内容排序。



sort -n numbers.txt
  1. uniq:移除或统计重复的行。



uniq -c names.txt
  1. xargs:构建并执行命令行。



find . -name "*.txt" | xargs grep "error"
  1. cut:从文件中提取字段。



cut -d';' -f1 data.csv
  1. tr:转换或删除字符。



tr '[:upper:]' '[:lower:]' < words.txt
  1. bc:计算器,用于处理数学运算。



echo "4 * 3" | bc
  1. date:显示和设置系统日期和时间。



date +"%Y-%m-%d %H:%M:%S"
  1. diff:比较两个文件的差异。



diff file1.txt file2.txt
  1. dd:复制和转换文件。



dd if=input.txt of=output.txt bs=1k
  1. wc:计算文件的单词数、行数等。



wc -l file.txt
  1. tar:压缩和解压文件。



tar -czvf archive.tar.gz /path/to/directory
  1. curl:传输数据,用于网络请求。



curl -O http://example.com/file.zip
  1. sort:排序命令行参数。



echo -e "apple\nbanana\ncherry" | sort
  1. tee:读取标准输入并写入文件和标准输出。



echo "Hello World" | tee file.txt

这些工具和命令是Shell脚本编写中的基本元素,每个工具都有其特定的用途,可以根据需要灵活使用。

2024-08-10

在Linux上安装DM8(达梦数据库)和SpringBoot集成达梦数据库的步骤如下:

  1. 安装DM8数据库:

    • 下载达梦数据库软件包。
    • 上传到Linux服务器。
    • 解压软件包(例如:unzip dm8_setup.zip)。
    • 运行安装脚本(例如:./dm8_installer.bin)。
    • 按照安装向导进行安装配置。
  2. 配置DM8数据库:

    • 根据需要配置数据库参数,例如端口、内存分配等。
    • 初始化数据库实例。
  3. SpringBoot集成达梦数据库:

    • pom.xml中添加达梦数据库驱动依赖。
    • 配置application.propertiesapplication.yml文件,包含达梦数据库的连接信息。
    • 使用JdbcTemplate或者MyBatis/Hibernate进行数据库操作。

示例代码:

pom.xml中添加达梦数据库驱动依赖:




<dependency>
    <groupId>com.dameng</groupId>
    <artifactId>DmJdbcDriver18</artifactId>
    <version>8.0.0.0</version>
</dependency>

application.properties中添加数据库连接配置:




spring.datasource.driver-class-name=dm.jdbc.driver.DmDriver
spring.datasource.url=jdbc:dm://localhost:5236
spring.datasource.username=SYSDBA
spring.datasource.password=dameng123

使用JdbcTemplate操作数据库:




import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;
 
@Repository
public class CustomRepository {
 
    @Autowired
    private JdbcTemplate jdbcTemplate;
 
    public void executeQuery() {
        jdbcTemplate.query("SELECT * FROM your_table", rs -> {
            // 处理查询结果
        });
    }
}

确保在集成过程中处理好数据库连接池配置、事务管理、异常处理等方面的细节。

2024-08-10

在Linux上进行网络速度测试,可以使用speedtest-cli工具。以下是安装和使用speedtest-cli的步骤:

  1. 安装speedtest-cli



# 使用curl安装speedtest-cli
curl -s https://raw.githubusercontent.com/sivel/speedtest-cli/master/speedtest.py | sudo python3 -
 
# 或者使用wget安装speedtest-cli
wget -O speedtest-cli https://raw.githubusercontent.com/sivel/speedtest-cli/master/speedtest.py
sudo chmod +x speedtest-cli
sudo mv speedtest-cli /usr/local/bin/
  1. 运行speedtest-cli以测试网速:



speedtest-cli

如果你想要得到简单的文本输出,可以使用:




speedtest-cli --simple

如果你想要得到JSON格式的输出,可以使用:




speedtest-cli --json

这些命令会提供网络的上传和下载速度等信息。

2024-08-10

在Linux环境下,可以使用screenminicom等串口调试工具进行串口测试。以下是使用screen进行串口通信的基本命令和步骤:

首先,安装screen




sudo apt-update
sudo apt-get install screen

然后,使用screen连接到串口设备:




screen /dev/ttyS0 115200

这里/dev/ttyS0是串口设备文件,115200是波特率。

screen会话中,你可以输入任何你想发送的数据,并且可以看到接收到的数据。

退出screen会话的快捷键是Ctrl-A然后按k,确认后退出。

如果你想要一个简单的串口测试程序,可以使用以下示例代码:




#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <termios.h>
 
int main() {
    int fd;
    struct termios options;
    char buffer[255];
    int bytes_read;
 
    fd = open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NDELAY);
    if (fd == -1) {
        perror("open_port: Unable to open serial port - ");
        return(-1);
    }
 
    // 获取并配置串口选项
    tcgetattr(fd, &options);
    cfsetispeed(&options, B115200); // 输入波特率
    cfsetospeed(&options, B115200); // 输出波特率
    options.c_cflag |= (CLOCAL | CREAD); // 开启接收
    options.c_cflag &= ~CSIZE; // 清除当前数据位设置
    options.c_cflag |= CS8;    // 8位数据位
    options.c_cflag &= ~PARENB; // 关闭校验位
    options.c_cflag &= ~CSTOPB; // 1位停止位
    options.c_cc[VMIN] = 1; // 读取最小字符数
    options.c_cc[VTIME] = 0; // 读取最小字符时间
    tcflush(fd, TCIFLUSH); // 清空输入缓冲区
 
    // 写入数据到串口
    write(fd, "Hello Serial!\n", 14);
 
    // 从串口读取数据
    bytes_read = read(fd, buffer, sizeof(buffer));
    if (bytes_read > 0) {
        buffer[bytes_read] = '\0';
        printf("Received: %s", buffer);
    }
 
    close(fd); // 关闭串口
    return 0;
}

这个程序会在打开的串口设备中写入"Hello Serial!",然后读取任何传入的数据并打印出来。

请确保你有适当的权限来访问串口设备,并且根据你的实际情况调整串口设备文件和波特率。

2024-08-10

在Linux环境下安装OpenCV可以通过源码编译或使用包管理器。以下是通过源码编译安装OpenCV的步骤:

  1. 安装依赖项:



sudo apt-update
sudo apt-get install build-essential cmake git pkg-config libgtk-3-dev \
libavcodec-dev libavformat-dev libswscale-dev libv4l-dev \
libxvidcore-dev libx264-dev libjpeg-dev libpng-dev libtiff-dev \
gfortran openexr libatlas-base-dev python3-dev python3-numpy \
libtbb2 libtbb-dev libdc1394-22-dev
  1. 克隆OpenCV的Git仓库:



git clone https://github.com/opencv/opencv.git
cd opencv
git checkout <opencv-version>  # 替换<opencv-version>为想要的版本号,例如4.5.2
  1. 克隆OpenCV额外模块的Git仓库:



cd ..
git clone https://github.com/opencv/opencv_contrib.git
cd opencv_contrib
git checkout <opencv_contrib-version>  # 替换<opencv_contrib-version>为对应的版本号
  1. 编译OpenCV:



cd ..
mkdir build
cd build
cmake -D CMAKE_BUILD_TYPE=RELEASE \
      -D CMAKE_INSTALL_PREFIX=/usr/local \
      -D INSTALL_C_EXAMPLES=ON \
      -D INSTALL_PYTHON_EXAMPLES=ON \
      -D OPENCV_GENERATE_PKGCONFIG=ON \
      -D OPENCV_EXTRA_MODULES_PATH=../opencv_contrib/modules \
      -D BUILD_EXAMPLES=ON ..
make -j$(nproc)  # 使用所有CPU核心进行编译
sudo make install
sudo ldconfig
  1. 验证安装:



pkg-config --modversion opencv4

如果您使用的是Python,您可能还需要设置PYTHONPATH环境变量:




export PYTHONPATH=/usr/local/lib/python3.6/dist-packages:$PYTHONPATH

请根据您的Python版本和OpenCV版本调整上述命令中的路径。

2024-08-10

在Linux中,您可以使用nohup命令配合&符号来在后台运行Java项目。nohup命令可以防止在您退出终端后程序被中断,而&则是将程序放入后台执行。

以下是一个示例命令,它将启动一个Java应用程序并将输出重定向到当前目录下的app.log文件中,即使您退出当前会话,Java应用程序也会继续运行:




nohup java -jar your-application.jar > app.log 2>&1 &

解释:

  • java -jar your-application.jar 是启动Java应用程序的命令。
  • > 是重定向标准输出到文件的符号。
  • app.log 是输出文件的名称。
  • 2>&1 是将标准错误(stderr,文件描述符为2)重定向到标准输出(stdout,文件描述符为1)。
  • & 是将命令放入后台执行。
  • nohup 是使命令忽略挂断信号。

执行上述命令后,您会得到一个进程的PID,可以使用kill命令通过这个PID来停止程序,或者使用jobs命令查看并管理后台任务。

2024-08-10

adduser 是一个在 Linux 系统中用于创建新用户的命令。这个命令可以创建用户账户,设置用户密码,并且通常会自动创建用户的家目录。

基本语法:




adduser [options] username

示例:

  1. 创建一个新用户:



sudo adduser johndoe
  1. 创建用户并设置密码:



sudo adduser --password passw0rd johndoe
  1. 创建用户并指定用户信息:



sudo adduser --home /home/johndoe --shell /bin/bash --no-user-group --group johndoe --ingroup users johndoe

在这个例子中,--home 指定了用户的家目录,--shell 指定了用户的默认 shell,--no-user-group 表示不创建与用户同名的组,--group 指定了用户所属的主组,--ingroup 指定了用户所属的附加组。

请注意,你需要具有足够的权限来创建用户,通常需要使用 sudo

2024-08-10

心跳机制是一种检测TCP连接存活的方式,通常在没有数据传输的空闲时间间隔发送一个特殊的数据包,以此来确认连接的有效性。

在Linux下使用socket编程实现心跳机制,通常需要设置socket选项SO_KEEPALIVE,并且可以设置相关参数tcp_keepalive_timetcp_keepalive_intvltcp_keepalive_probes来调整心跳的行为。

以下是一个简单的示例,展示如何在客户端和服务器端设置心跳机制:

服务器端设置心跳:




int enable = 1;
if (setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE, &enable, sizeof(enable)) < 0) {
    // 设置socket选项SO_KEEPALIVE
    perror("setsockopt keepalive");
}

客户端设置心跳:




int enable = 1;
if (setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE, (void *)&enable, sizeof(enable)) < 0) {
    // 设置socket选项SO_KEEPALIVE
    perror("setsockopt keepalive");
}

心跳的间隔和重试次数可以通过以下方式设置:




int time = 75; // 每75秒发送心跳包
int interval = 5; // 连续5次心跳包没有响应则认为连接断开
int probes = 2; // 发送心跳包的次数
 
setsockopt(sockfd, IPPROTO_TCP, TCP_KEEPIDLE, &time, sizeof(time));
setsockopt(sockfd, IPPROTO_TCP, TCP_KEEPINTVL, &interval, sizeof(interval));
setsockopt(sockfd, IPPROTO_TCP, TCP_KEEPCNT, &probes, sizeof(probes));

在实际应用中,心跳包通常是自定义的数据,发送的内容可以是特定的字节序列,用来确保连接的有效性。在接收方,如果连续一段时间内没有接收到心跳包,可以主动关闭连接,或者发送报警信息。

2024-08-10

WSL2 Linux子系统是Windows 10和Windows 11的特性,它允许用户在Windows上运行Linux子系统,而不需要虚拟机或双引导设置。这是一个高级主题,涉及到配置和管理Linux环境。

如果您需要在WSL2中安装软件,您可以使用Linux命令行界面。以下是一些基本步骤:

  1. 打开WSL2 Linux子系统。
  2. 确保您的子系统是最新的,并且已经安装了所需的Linux发行版。
  3. 使用Linux包管理器安装软件。不同的Linux发行版有不同的包管理器,例如Debian和Ubuntu使用apt,而Fedora和CentOS使用yumdnf

例如,在Ubuntu中安装软件:




sudo apt update          # 更新软件包列表
sudo apt upgrade         # 升级所有可升级的软件包
sudo apt install <package_name>  # 安装软件包

如果您需要安装特定版本的软件包或者从PPA安装,您可以使用apt-getapt命令的特定选项。

如果您需要更具体的命令或步骤,请提供更多的上下文信息。

2024-08-10

TinyProxy 是一个轻量级的 HTTP 和 HTTPS 代理服务器,适用于类 Unix 系统。以下是如何在 Linux 系统上安装和配置 TinyProxy 以便使用它访问互联网的步骤:

  1. 安装 TinyProxy:



sudo apt-get update
sudo apt-get install tinyproxy
  1. 配置 TinyProxy:

编辑 TinyProxy 的配置文件 /etc/tinyproxy/tinyproxy.conf。你可能需要调整以下设置:

  • Port:代理服务器监听的端口,默认为 8888。
  • Allow:允许连接到代理服务器的客户端 IP 地址范围,默认为 127.0.0.1
  • Deny:拒绝连接到代理服务器的客户端 IP 地址范围。
  • Authenticate:是否需要身份验证。
  • UsernamePassword:身份验证所需的用户名和密码。

例如,将监听端口改为 8080:




Port 8080
  1. 启动 TinyProxy 服务:



sudo systemctl start tinyproxy
  1. 配置防火墙允许访问 TinyProxy 端口(如果有防火墙运行):



sudo ufw allow 8080/tcp
  1. 客户端配置:

在需要通过 TinyProxy 访问互联网的客户端上,设置代理服务器地址为第一台 Linux 服务器的 IP 地址和 TinyProxy 监听的端口。

例如,在命令行中使用环境变量:




export http_proxy=http://<tinyproxy-server-ip>:8080
export https_proxy=https://<tinyproxy-server-ip>:8080

或者在浏览器设置中指定代理服务器。

以上步骤和配置是基于默认设置,根据实际需求和安全策略可能需要进行相应的调整。