UNIX/Linux系统管理技术手册

书架上的这块大部头书在5.1的时候终于有时间来学习了,本文将长期更新,记录UNIX/Linux系统管理技术手册学习中的疑问与解答。该书在豆瓣评分颇高,UNIX/Linux系统管理技术手册.勘误表在本文最后,如有疑问欢迎留言讨论。

笔记中实际操作的系统来自于ubuntu,运行在一款古董级的hp笔记本上,在Macbook Pro中运行了一台centos7虚拟机,电脑卡的时候关闭该虚拟机使用hp笔记本中的虚拟机。

leveldb中的LRUCache学习

由于查询内存要远比查询mongo数据库快,为了减少数据库查询压力,提升业务进程处理速度,实现了一个简单的lrucache,笔记链接

mongoc-c-driver使用教程

ubuntu install MongoDB

Installing the MongoDB C Driver (libmongoc) and BSON library (libbson)

strace命令使用实例

strace命令

strace是Linux上的一个很好用的工具,它可以用来输出程序在运行过程中发生的系统调用以及收到的信号的相关信息,因此在调试和诊断问题时有很大的帮助,特别是在程序没有源码,或是在前期做一些粗略的分析时。strace命令格式如下:

strace [options] command [args]

查看帮助

strace -h

查看版本信息

strace -V

基本使用

举个例子:

[root cprogs2]#strace sleep 300

execve("/bin/sleep", ["sleep", "300"], 0x7ffc2a8576d8......

Linux进程间资源共享

周末整理笔记,发现已经有接近一年的笔记等待整理,主要是Linux进程间资源共享,包括变量、锁、函数,很多笔记中没有记录引用链接,这是个不好的习惯。

Linux内核中是不存在线程的概念的,一切可执行单元都是进程。所谓多线程,其实是一组可以共享内存的进程,即“轻量级进程”。所以应该只要实现内存共享,就能让进程之间互相访问。同一个进程的多个线程天然具有上面的特性。

变量共享

master.c

#include <time.h>

#include <stdio.h>

#include <stdlib.h>

#include <assert.......

rename 函数使用注意事项

看日志中的rename函数的一个报错信息:Invalid cross-device link,花几分钟google搜索之后确定不是问题,记录下相关排查和验证过程。

man手册里的资料:

EXDEV The links named by new and old are on different file systems and the implementation does not support links between file systems.

返回EXDEV这个错误码是由于old和new位于不同的文件系统。为了验证这一观点,我从床底下搬出了我的上古时期的笔记本,......

Linux性能优化实践

本文是学习极客时间《Linux性能优化实战》课程,针对课程中用到的一些命令的学习笔记。

课程信息

ps命令不加参数执行ps

[root ~]#ps

PID TTY TIME CMD

4273 pts/0 00:00:00 bash

9507 pts/0 00:00:00 ps

[root ~]#

结果默认会显示4列信息。

PID: 运行着的命令(CMD)的进程编号

TTY: 命令所运行的位置(终端)

TIME: 运行着的该命令所占用的CPU处理时间

CMD: 该进程所运行的命令

显示所有进程

ps -ax,命令结果可能很长,可以配合les......

系统程序员成长计划

线程参数共享的问题

执行如下三个例子,观察执行结果,分析原因:

#include <stdio.h>

#include <pthread.h>

#include <assert.h>

void *start_routine(void * param)

{

int index = *(int *)param;

printf("%s:%d\n",__func__,index);

return NULL;

}

#define THREADS_NR 10

void create_test_threads()

{

int i = 0;

......

无锁队列

在分布式系统中经常会使用到共享内存,然后多个进程并行读写同一块共享内存,这样就会造成并发冲突的问题, 一般的常规做法是加锁,但是锁对性能的影响非常大,所以就搞出来了一个无锁队列。

无锁队列的关键原理是CPU提供了一个指令CAS,这条指令是一个原子指令,执行过程中不允许被打断。

它接受三个参数:需要修改值的地址、旧值、新值;CAS指令执行时先读取该地址的当前值,将当前值于旧值进行比较, 如果相等则说明此值没有被修改过将当前值更新为新值,操作成功;

如果不相等则说明此值被其他进程修改过,直接返回失败,此时需要程序重新读取最新的值,再次调用CAS指令进行更新,重复此步骤直到成功......

chroot用法

chroot命令用来在指定的根目录下运行指令。chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以/,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为/位置。

在经过 chroot 命令之后,系统读取到的目录和文件将不在是旧系统根下的而是新根下(即被指定的新的位置)的目录结构和文件,因此它带来的好处大致有以下3个:

增加了系统的安全性,限制了用户的权力:

在经过 chroot 之后,在新根下将访问不到旧系统的根目录结构和文件,这样就增强了系统的安全性。......