《Linux下使用uuid命令生成唯一标识符C语言实现方法》
UUID(Universally Unique Identifiers),通用唯一识别码,是一种软件建构的标准,亦为自动化的标识计算机上的软硬件设备及应用。UUID 的目的,是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。而在Linux下,可以使用uuid命令来生成唯一标识符,本文将介绍在C语言环境下,如何使用uuid命令生成uuid。
uuid命令在Linux下是通过libuuid库来生成一个唯一的UUID值,其实就是一个128位的数字,用来标识一个特定的资源,并保证全球范围内的唯一性。
可以使用如下命令来生成uuid:
$ uuidgen
输出示例:673c2135-5519-4550-bac0-64bdea831fca
可以使用如下C语言代码来调用uuid命令,生成UUID:
#include #include #include int main(){FILE *fp;char buffer[128];char cmd[128];sprintf(cmd, "uuidgen");fp = popen(cmd, "r");if (fp == NULL) {perror("Failed to run command\n");exit(1);}while (fgets(buffer, sizeof(buffer) - 1, fp) != NULL) {printf("UUID= %s", buffer);}pclose(fp);return 0;}
上述代码中,使用popen函数来调用命令,然后使用fgets函数把命令的输出保存到buffer数组中,最后使用pclose函数来关闭文件句柄。
如果想把这个唯一标识符保存在变量中,可以使用如下代码:
#include #include #include int main(){FILE *fp;char buffer[128];char cmd[128];sprintf(cmd, "uuidgen");char uuid[128]={0};fp = popen(cmd, "r");if (fp == NULL) {perror("Failed to run command\n");exit(1);}while (fgets(buffer, sizeof(buffer) -1, fp)!=NULL){snprintf(uuid, sizeof(uuid), "%s", buffer);}pclose(fp);printf("UUID= %s\n", uuid);return 0;}
以上就是使用uuid命令在C语言中生成唯一标识符的方法。使用此方法,可以快速生成唯一的UUID,用于标识资源,达到资源唯一性的目的。
香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
在linux中怎样只输出一个文件中含有*的那些行
使用正则表达式 例如grep /* escept /因为在linux里面“*”本身就是一个正则标识符 所以要转义下才能正确查找

创建一个script,Linux shell脚本
和C语言类似,在Shell中用if、then、elif、else、fi这几条命令实现分支控制。 这种流程控制语句本质上也是由若干条Shell命令组成的,例如先前讲过的if [ -f ~/ ]; then ~/ fi其实是三条命令,if [ -f ~/]是第一条,then .~/是第二条,fi是第三条。 如果两条命令写在同一行则需要用;号隔开,一行只写一条命令就不需要写;号了,另外,then后面有换行,但这条命令没写完,Shell会自动续行,把下一行接在then后面当作一条命令处理。 和[命令一样,要注意命令和各参数之间必须用空格隔开。 if命令的参数组成一条子命令,如果该子命令的Exit Status为0(表示真),则执行then后面的子命令,如果Exit Status非0(表示假),则执行elif、else或者fi后面的子命令。 if后面的子命令通常是测试命令,但也可以是其它命令。 Shell脚本没有{}括号,所以用fi表示if语句块的结束。 见下例:#! /bin/shif [ -f /bin/bash ] then echo /bin/bash is a file else echo /bin/bash is NOT a file fi if :; then echo always true; fi:是一个特殊的命令,称为空命令,该命令不做任何事,但Exit Status总是真。 此外,也可以执行/bin/true或/bin/false得到真或假的Exit Status。 再看一个例子:#! /bin/sh echo Is it morning? Please answer yes or no. read YES_OR_NO if [ $YES_OR_NO = yes ]; then echo Good morning! elif [ $YES_OR_NO = no ]; then echo Good afternoon! else echo Sorry, $YES_OR_NO not recognized. Enter yes or no. exit 1 fi exit 0上例中的read命令的作用是等待用户输入一行字符串,将该字符串存到一个Shell变量中。 此外,Shell还提供了&&和||语法,和C语言类似,具有Short-circuit特性,很多Shell脚本喜欢写成这样:test $(whoami) != root && (echo you are using a non-privileged account; exit 1)&&相当于逗...地,而||相当于逗if ...地。 &&和||用于连接两个命令,而上面讲的-a和-o仅用于在测试表达式中连接两个测试条件,要注意它们的区别,例如,test $VAR -gt 1 -a $VAR -lt 3和以下写法是等价的test $VAR -gt 1 && test $VAR -lt 3
Linux下磁盘分区的uuid是根据哪些参数得的
UUID在文件系统中的使用UUID可以持久唯一标识一个硬盘分区。 其实方式很简单,就是在文件系统的超级块中使用128位存放UUID。 这个UUID是在使用文件系统格式化分区时计算生成的,例如Linux下的文件系统工具mkfs就在格式化分区的同时,生成UUID并把它记录到超级块的固定区域中。 下面是ext2文件系统超级块结构:struct ext2_super_block{ __u32 s_inodes_count;/* 文件系统中索引节点总数 */__u32 s_blocks_count;/*文件系统中总块数 */__u32 s_r_blocks_count; /* 为超级用户保留的块数 */__u32 s_free_blocks_count; /*文件系统中空闲块总数 */__u32 s_free_inodes_count; /*文件系统中空闲索引节点总数*/__u32 s_first_data_block;/* 文件系统中第一个数据块 */__u32 s_log_block_size;/* 用于计算逻辑块大小 */__s32 s_log_frag_size;/* 用于计算片大小 */__u32 s_blocks_per_group; /* 每组中块数 */__u32 s_frags_per_group;/* 每组中片数 */__u32 s_inodes_per_group; /* 每组中索引节点数 */__u32 s_mtime;/*最后一次安装操作的时间 */__u32 s_wtime; /*最后一次对该超级块进行写操作的时间 */__u16 s_mnt_count; /* 安装计数 */__s16 s_max_mnt_count; /* 最大可安装计数 */__u16 s_magic;/* 用于确定文件系统版本的标志 */__u16 s_state;/* 文件系统的状态*/__u16 s_errors; /* 当检测到有错误时如何处理 */__u16 s_minor_rev_level;/* 次版本号 */__u32 s_lastcheck; /* 最后一次检测文件系统状态的时间 */__u32 s_checkinterval; /* 两次对文件系统状态进行检测的间隔时间 */__u32 s_rev_level; /* 版本号 */__u16 s_def_resuid;/* 保留块的默认用户标识号 */__u16 s_def_resgid;/* 保留块的默认用户组标识号*//** These fields are for EXT2_DYNAMIC_REV superblocks only.** Note: the difference between the compatible feature set and* the incompatible feature set is that if there is a bit set* in the incompatible feature set that the kernel doesnt* know about, it should refuse to mount the filesystem.** e2fscks requirements are more strict; if it doesnt know* about a feature in either the compatible or incompatible* feature set, it must abort and not try to meddle with* things it doesnt understand...*/__u32 s_first_ino;/* 第一个非保留的索引节点 */__u16 s_inode_size; /* 索引节点的大小 */__u16 s_block_group_nr; /* 该超级块的块组号 */__u32 s_feature_compat; /* 兼容特点的位图*/__u32 s_feature_incompat; /* 非兼容特点的位图 */__u32 s_feature_ro_compat;/* 只读兼容特点的位图*/__u8s_uuid[16]; /* 128位的文件系统标识号*/chars_volume_name[16];/* 卷名 */chars_last_mounted[64]; /* 最后一个安装点的路径名 */__u32 s_algorithm_usage_bitmap; /* 用于压缩*//** Performance preallocation should only* happen if the EXT2_COMPAT_PREALLOC flag is on.*/__u8s_prealloc_blocks;/* 预分配的块数*/__u8s_prealloc_dir_blocks;/* 给目录预分配的块数 */__u16 s_padding1;__u32 s_reserved[204];/* 用null填充块的末尾 */};可以看到s_uuid[16]就是存放分区UUID的地方。 这样,无论硬盘分区的标识就永远不会重复,而且只要分区没有被重新格式化,那么标识此分区的UUID永远不变。
发表评论