精华内容
下载资源
问答
  • 用户管理之用户配置文件

    千次阅读 2019-05-11 13:51:02
    文章目录一、用户信息文件二、影子文件三、组信息文件四、其他与用户管理相关...不过没关系,我们可以利用帮助命令 man 5 passwd 来看一下 passwd 配置文件的作用。 主要就是看图中圈出来的那两行,它告诉我们,pas...

    一、用户信息文件

    用户信息文件的存放路径是 /etc/passwd,用 vim 查看一下文件内容:
    在这里插入图片描述
    乍一看好像眼花缭乱的,没有头绪。不过没关系,我们可以利用帮助命令 man 5 passwd 来看一下 passwd 配置文件的作用。

    在这里插入图片描述

    主要就是看图中圈出来的那两行,它告诉我们,passwd 配置文件的每一行代表一个用户,而每个用户信息的格式如下:

    account:password:UID:GID:GECOS:directory:shell
    

    可以看到,每个用户信息有 7 个字段,字段之间用冒号隔开,下面分别解释一下这 7 个字段的含义:

    • 第 1 字段:用户名称

    • 第 2 字段:密码标志。密码标志位如果是 x,代表该用户有密码,密码文件存放在 /etc/shadow 中;如果密码标志位为空,系统会认为该用户没有密码,在登录的时候不用输入密码就可以登录,但是这种方式只能在本地登录,不能通过远程登录。

    • 第 3 字段:用户 ID。ID 范围不同代表的用户类型不同:

      • 0:超级用户
      • 1-499:系统用户(伪用户)
      • 500-65535:普通用户

      伪用户是供系统启动一些命令或服务调用的,对于系统至关重要,这些用户千万不能删除!

      系统其实是通过用户 ID 来识别不同的用户的。如果你想把一个普通用户变成超级用户,只需要把该用户的 ID 改成 0 就可以,这时系统会把所有 ID 相同的用户当成一个用户来看待。

    • 第 4 字段:GID(用户初始组 ID)

    • 每一个用户被创建的时候,系统都会创建一个和这个用户名相同的组,该用户默认属于这个组。用户的初始组可以更改,但是只能有一个;还有一个概念是「附加组」,是指用户可以加入多个其他的用户组,并拥有这些组的权限,用户的附加组可以有多个。

      如果你想知道该用户的初始组 ID 到底对应着哪一个组,可以查看 /etc/group 文件。

    • 第 5 字段:备注。

    • 第 6 字段:用户的家目录。即用户的初始登录位置。普通用户的家目录是 /home/用户名/,超级用户的家目录是 /root/

    • 第 7 字段:登录之后的 Shell。Shell 就是 Linux 的 命令解释器。如果想禁用某个用户,可以将该用户的命令解释器改成除 /bin/bash 以外的任何字符串,这样,用户就无法登录了。如果想解除禁用,把他的命令解释器再改成 /bin/bash 就可以了。

    二、影子文件

    顾名思义,该文件是前面讲过的用户信息文件的影子文件,存放路径是 /etc/shadow
    在这里插入图片描述
    这个文件的权限是 000,但是 root 用户不受权限的限制,可以读写该文件的内容。我们先用 vim 查看一下文件内容:
    在这里插入图片描述
    与用户信息文件一样,该文件也是每一行代表一个用户,不同的是,该文件的每一行有 9 个字段,下面一一解释这 9 个字段的含义。

    • 第 1 字段:用户名。

    • 第 2 字段:加密密码。加密算法为 SHA512 散列加密算法,如果密码位是「!!」或「*」,代表没有密码,不能登录。

    • 第 3 字段:密码最后一次的修改日期。使用 1970 年 1 月 1 日作为标准时间。每过一天时间戳加 1。

    • 第 4 字段:允许修改密码的日期间隔,以「天」为单位。比如说:如果是 0,则表示没有限制;如果是 10,则表示假如今天修改了密码,要等到至少 10 天之后才能再次修改密码。

    • 第 5 字段:密码有效期,也是以「天」为单位

    • 第 6 字段:密码修改到期前的警告天数。也就是说,假设第 5 字段是 90,第 6 字段是 7,那么从更改密码之后的第 83 天开始,每次登录的时候,Linux 都会发出警告,提醒你更改密码。

    • 第 7 字段:密码到期之后的宽限天数。如果为空或者 0,表示密码到期后立即失效,用户将无法登录;如果是 -1,表示密码到期后永远不会失效,用户依然能使用该密码继续登录。

    • 第 8 字段:用户有效期,用时间戳表示。也就是从 1970 年 1 月 1 日开始算的第多少天。用户有效期到了之后,不管该用户的密码到没到期,都不能再登录了。

    • 对于人来说,时间戳可能不是那么直观,我们更习惯于用年月日表示日期。好在 Linux 中有相关的命令可以实现时间戳和年月日的相互转换。

      date -d "1970-01-01 17993 days" //把16066转换成日期
      echo $(($(date --date="2019/05/05" +%s)/86400+1)) //把2019/05/05转换成时间戳
      
    • 第 9 字段:保留。

    三、组信息文件

    组信息文件中存放的是组的相关信息,存放路径是 /etc/group

    在 Linux 中,每创建一个用户,都会创建一个组名跟用户名一样的组,作为该用户的初始组。

    Windows 中是每创建一个用户,都会默认放在 Users 组里。

    用 vim 查看一下文件内容:
    在这里插入图片描述
    该文件的每一行代表一个组,每个组信息用 4 个字段,下面详细介绍一下每个字段的含义:

    • 第 1 字段:组名。
    • 第 2 字段:密码标志。这里的密码指的是组密码。组密码文件存放在 /etc/gshadow 中。组密码有什么作用呢?本来组成员是只有 root 用户可以添加删除的,当 root 用户给某个组设置了组管理员和组密码,组管理员就可以往这个组里加减成员。这样一来就相当于给这个组认命了一个组长,这个组长可以行使 root 用户添加删除组成员的权利。但是这样会削减系统的安全性,所以并不推荐使用组密码。
    • 第 3 字段:GID。即组 ID。
    • 第 4 字段:组中附加用户。

    四、其他与用户管理相关的文件

    用户的家目录

    用户的家目录是用户的初始登录位置。

    • 普通用户:/home/用户名/,所有者和所属组都是此用户,权限是 700
    • 超级用户:/root/,所有者和所属组都是 root 用户,权限是 550

    用户的邮箱

    路径:/var/spool/mail/用户名

    用户模板目录

    路径:/etc/skel/

    在创建用户时,该目录中的文件会被复制到用户的家目录下。也可以手动在该目录下创建一些自定义的文件,在创建用户时,自定义的文件也会被复制到用户的家目录下。

    展开全文
  • Linux用户用户配置文件详解

    千次阅读 2019-03-30 13:41:32
    作为一个Linux管理员,对用户增删改查等操作当然离不开用户用户组的配置文件了,熟练的掌握与运用用户用户组的配置文件是必不可少的学习一步,接下来我会详细介绍用户用户组的配置文件。 1、与用户有关的配置...

    Linux用户与用户组配置文件详解

    出发点

    Linux是一个多用户多任务的操作系统,用户需要使用系统,就必须在系统中拥有属于自己的账号。
    作为一个Linux管理员,对用户增删改查等操作当然离不开用户与用户组的配置文件了,熟练的掌握与运用用户与用户组的配置文件是必不可少的学习一步,接下来我会详细介绍用户与用户组的配置文件。

    1、与用户有关的配置文件(/etc/passwd),所有用户权限为可读

    Linux基本思想之一:一切都是文件

    passwd:存放用户账户及其相关信息(密码除外)

    vim打开passwd用户配置文件
    在这里插入图片描述
    在这里插入图片描述
    passwd文件中包含了系统所有用户的基本信息,一行定义一个用户账户,每行均由7个不同的字段构成,各字段用“:”分割

    第一个字段(第一个root):用户名
    第二个字段(x):加密的密码(为了安全去,使用“x”占位代表)
    第三个字段(第一个0):用户ID
    第四个字段(第二个0):用户组ID
    第五个字段(第二个root):用户的描述信息(默认用户的全名或空值)
    第六个字段(/root):用户的主目录
    第七个字段(/bin/bash):登录shell(字段为/sbin/nologin,表示禁止登录)

    用户名:加密的密码:UID:GID:用户名全名或描述信息:用户主目录:登录shell

    如果要禁用某个用户账户,可以修改/etc/passwd文件,在该用户对应的行首添加“#”符号(linux中行首第一个字符为#,代表这一行为注释),或者用户的shell设置为/sbin/nologin

    2、用户账户密码信息配置文件(/etc/shadow),只有超级用户root可读,普通用户无法读取

    shadow文件中,每个用户信息也是占用一行,由9个字段组成,中间用冒号“:”分割

    vim打开shadow配置文件
    在这里插入图片描述
    在这里插入图片描述

    从左往右依次是:
    第一个字段(root):用户名
    第二个字段($…0):加密后的密码(如果为空,用户不需要输入密码即可登录)
    第三个字段(空值):密码的最后一次修改时间(这是一个相对时间,即从1970年1月1日到修改时的天数)
    第四个字段(0):密码在多少天内不能更改
    第五个字段(99999):密码在多少天后必须更改
    第六个字段(7):密码到期前多少天给用户发出警告
    第七个字段(空值):密码在多少天后用户账户将被禁用
    第八个字段(空值):密码被禁用的具体日期(这是一个相对时间,即从1970年1月1日到禁止时的天数)
    第九个字段(空值):保留字段

    通过vim打开/etc/shadow文件,通过修改相关内容可以达到管理用户的目的

    3、设置用户属性的配置文件(/etc/login.defs)

    建立用户账户是会根据/etc/login.defs文件的配置信息设置用户的某些属性

    vim打开login.defs
    在这里插入图片描述
    在这里插入图片描述
    MAIL_DIR /var/spool/mail (用户邮箱所在的目录)
    PASS_MAX_DAYS 99999 (账户密码最长有效天数)
    PASS_MIN_DAYS 0 (账户密码最短有效天数)
    PASS_MIN_LEN 5 (账户密码的最小长度)
    PASS_WARN_AGE 7 (账户密码过期前,提前警告的天数)
    UID_MIN 1000 (使用useradd命令添加账户是自动产生UID,最小UID值)
    UID_MAX 60000 (使用useradd命令添加账户是自动产生UID,最大UID值)
    SYS_UID_MIN 201 (使用useradd -r 添加账户时自动产生的系统UID,最小UID值)
    SYS_UID_MAX 999 使用useradd -r 添加账户时自动产生的系统UID,最大UID值)
    GID_MIN 1000 (使用groupadd命令添加账户组时自动产生GID,最小GID值)
    GID_MAX 60000 (使用groupadd命令添加账户组时自动产生GID,最大GID值)
    SYS_GID_MIN 201 使用groupadd -r 添加账户组时自动产生的系统GID,最小GID值)
    SYS_GID_MAX 999 使用groupadd -r 添加账户组时自动产生的系统GID,最大GID值)
    CREATE_HOME yes (创建用户时是否为用户创建主目录)
    USERGROUPS_ENAB yes (创建用户是是否为用户常见同名的组)
    ENCRYPT_METHOD SHA512 (密码加密方式)

    /etc/login.defs文件中某些设置不会影响超级管理员root用户

    4、用户组管理配置文件(/etc/group)

    group文件用于存放用户组的加密密码,每个用户组账户的信息在改文件中占用一行,每行分为4个字段,中间用“:”分割
    通过修改group文件,达到管理用户组的目的。

    vim打开group

    在这里插入图片描述
    在这里插入图片描述

    组名:加密后的组密码:GID:组成员列表

    第一个字段(root):用户组的组名
    第二个字段(x):加密后的用户组密码
    第三个字段(0):用户组ID,GID
    第四个字段(空值):用户组的成员列表(多个组成员用逗号分割)

    group文件中,用户的主组并不把该用户作为成员列出,只有用户的附属组才能把该用户作为成员列出

    5、用户组密码配置文件(/etc/gshadow)

    gpasswd用于存放组的加密密码,每个组账户在该行占用一行,每行分为4个字段,中间用“:”分割

    vim打开gshadow
    在这里插入图片描述
    在这里插入图片描述

    组名:加密后的组密码:组的管理员:组成员列表

    第一个字段(root):用户组的组名
    第二个字段(空值):加密后的用户组密码(空值代表没密码)
    第三个字段(空值):用户组管理员(空值代表无组管理员)
    第四个字段(空值):用户组的成员列表(空值代表无成员列表)

    可以通过修改gshadow文件达到管理用户组的目的

    展开全文
  • MySQL目录结构以及配置文件详解

    万次阅读 多人点赞 2018-01-03 12:42:46
    昨天给大家进行了数据库介绍,今天将正式带领大家进入我们的课题MySQL讲解部分,首先给大家介绍一下MySQL安装后的目录结构和配置文件详解。 一、MySQL的目录结构  1、bin目录  用于放置一些可执行文件,...

           昨天给大家进行了数据库介绍,今天将正式带领大家进入我们的课题MySQL讲解部分,首先给大家介绍一下MySQL安装后的目录结构和配置文件详解。

    一、MySQL的目录结构


       1、bin目录

            用于放置一些可执行文件,如mysql.exe、mysqld.exe、mysqlshow.exe等。

       2、data目录

            用于放置一些日志文件以及数据库。

       3、include目录

            用于放置一些头文件,如:mysql.h、mysql_ername.h等。

       4、lib目录

            用于放置一系列库文件。

       5、share目录

            用于存放字符集、语言等信息。

       6、my.ini

            MySQL数据库中使用的配置文件。

       7、my-huge.ini

            适合超大型数据库的配置文件。

       8、my-large.ini

            适合大型数据库的配置文件。

       9、my-medium.ini

            适合中型数据库的配置文件。

       10、my-small.ini

            适合小型数据库的配置文件。

       11、my-template.ini

            是配置文件的模板,MySQL配置向导将该配置文件中选择项写入到my.ini文件。

       12、my-innodb-heavy-4G.ini

            表示该配置文件只对于InnoDB存储引擎有效,而且服务器的内存不能小于4GB。

    二、配置文件参数详解

    [client]
    port = 3306
    socket = /tmp/mysql.sock

    [mysqld]
    port = 3306
    socket = /tmp/mysql.sock

    basedir = /usr/local/mysql
    datadir = /data/mysql
    pid-file = /data/mysql/mysql.pid
    user = mysql
    bind-address = 0.0.0.0
    server-id = 1 #表示是本机的序号为1,一般来讲就是master的意思

    skip-name-resolve
    # 禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。但需要注意,如果开启该选项,
    # 则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求

    #skip-networking

    back_log = 600
    # MySQL能有的连接数量。当主要MySQL线程在一个很短时间内得到非常多的连接请求,这就起作用,
    # 然后主线程花些时间(尽管很短)检查连接并且启动一个新线程。back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。
    # 如果期望在一个短时间内有很多连接,你需要增加它。也就是说,如果MySQL的连接数据达到max_connections时,新来的请求将会被存在堆栈中,
    # 以等待某一连接释放资源,该堆栈的数量即back_log,如果等待连接的数量超过back_log,将不被授予连接资源。
    # 另外,这值(back_log)限于您的操作系统对到来的TCP/IP连接的侦听队列的大小。
    # 你的操作系统在这个队列大小上有它自己的限制(可以检查你的OS文档找出这个变量的最大值),试图设定back_log高于你的操作系统的限制将是无效的。

    max_connections = 1000
    # MySQL的最大连接数,如果服务器的并发连接请求量比较大,建议调高此值,以增加并行连接数量,当然这建立在机器能支撑的情况下,因为如果连接数越多,介于MySQL会为每个连接提供连接缓冲区,就会开销越多的内存,所以要适当调整该值,不能盲目提高设值。可以过'conn%'通配符查看当前状态的连接数量,以定夺该值的大小。

    max_connect_errors = 6000
    # 对于同一主机,如果有超出该参数值个数的中断错误连接,则该主机将被禁止连接。如需对该主机进行解禁,执行:FLUSH HOST

    open_files_limit = 65535
    # MySQL打开的文件描述符限制,默认最小1024;open_files_limit没有被配置的时候,比较max_connections*5ulimit -n的值,哪个大用哪个,
    # open_file_limit被配置的时候,比较open_files_limitmax_connections*5的值,哪个大用哪个。

    table_open_cache = 128
    # MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。默认值64
    # 假定系统有200个并发连接,则需将此参数设置为200*N(N为每个连接所需的文件描述符数目)
    # 当把table_open_cache设置为很大时,如果系统处理不了那么多文件描述符,那么就会出现客户端失效,连接不上

    max_allowed_packet = 4M
    # 接受的数据包大小;增加该变量的值十分安全,这是因为仅当需要时才会分配额外内存。例如,仅当你发出长查询或MySQLd必须返回大的结果行时MySQLd才会分配更多内存。
    # 该变量之所以取较小默认值是一种预防措施,以捕获客户端和服务器之间的错误信息包,并确保不会因偶然使用大的信息包而导致内存溢出。

    binlog_cache_size = 1M
    # 一个事务,在没有提交的时候,产生的日志,记录到Cache中;等到事务提交需要提交的时候,则把日志持久化到磁盘。默认binlog_cache_size大小32K

    max_heap_table_size = 8M
    # 定义了用户可以创建的内存表(memory table)的大小。这个值用来计算内存表的最大行数值。这个变量支持动态改变

    tmp_table_size = 16M
    # MySQLheap(堆积)表缓冲大小。所有联合在一个DML指令内完成,并且大多数联合甚至可以不用临时表即可以完成。
    # 大多数临时表是基于内存的(HEAP)表。具有大的记录长度的临时表 (所有列的长度的和)或包含BLOB列的表存储在硬盘上。
    # 如果某个内部heap(堆积)表大小超过tmp_table_sizeMySQL可以根据需要自动将内存中的heap表改为基于硬盘的MyISAM表。还可以通过设置tmp_table_size选项来增加临时表的大小。也就是说,如果调高该值,MySQL同时将增加heap表的大小,可达到提高联接查询速度的效果

    read_buffer_size = 2M
    # MySQL读入缓冲区大小。对表进行顺序扫描的请求将分配一个读入缓冲区,MySQL会为它分配一段内存缓冲区。read_buffer_size变量控制这一缓冲区的大小。
    # 如果对表的顺序扫描请求非常频繁,并且你认为频繁扫描进行得太慢,可以通过增加该变量值以及内存缓冲区大小提高其性能

    read_rnd_buffer_size = 8M
    # MySQL的随机读缓冲区大小。当按任意顺序读取行时(例如,按照排序顺序),将分配一个随机读缓存区。进行排序查询时,
    # MySQL会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySQL会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大

    sort_buffer_size = 8M
    # MySQL执行排序使用的缓冲大小。如果想要增加ORDER BY的速度,首先看是否可以让MySQL使用索引而不是额外的排序阶段。
    # 如果不能,可以尝试增加sort_buffer_size变量的大小

    join_buffer_size = 8M
    # 联合查询操作所能使用的缓冲区大小,和sort_buffer_size一样,该参数对应的分配内存也是每连接独享

    thread_cache_size = 8
    # 这个值(默认8)表示可以重新利用保存在缓存中线程的数量,当断开连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,
    # 如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,如果有很多新的线程,
    # 增加这个值可以改善系统性能.通过比较ConnectionsThreads_created状态的变量,可以看到这个变量的作用。(–>表示要调整的值)
    # 根据物理内存设置规则如下:
    # 1G  —> 8
    # 2G  —> 16
    # 3G  —> 32
    # 大于3G  —> 64

    query_cache_size = 8M
    #MySQL的查询缓冲大小(从4.0.1开始,MySQL提供了查询缓冲机制)使用查询缓冲,MySQLSELECT语句和查询结果存放在缓冲区中,
    # 今后对于同样的SELECT语句(区分大小写),将直接从缓冲区中读取结果。根据MySQL用户手册,使用查询缓冲最多可以达到238%的效率。
    # 通过检查状态值'Qcache_%',可以知道query_cache_size设置是否合理:如果Qcache_lowmem_prunes的值非常大,则表明经常出现缓冲不够的情况,
    # 如果Qcache_hits的值也非常大,则表明查询缓冲使用非常频繁,此时需要增加缓冲大小;如果Qcache_hits的值不大,则表明你的查询重复率很低,
    # 这种情况下使用查询缓冲反而会影响效率,那么可以考虑不用查询缓冲。此外,在SELECT语句中加入SQL_NO_CACHE可以明确表示不使用查询缓冲

    query_cache_limit = 2M
    #指定单个查询能够使用的缓冲区大小,默认1M

    key_buffer_size = 4M
    #指定用于索引的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写),到你能负担得起那样多。如果你使它太大,
    # 系统将开始换页并且真的变慢了。对于内存在4GB左右的服务器该参数可设置为384M512M。通过检查状态值Key_read_requestsKey_reads
    # 可以知道key_buffer_size设置是否合理。比例key_reads/key_read_requests应该尽可能的低,
    # 至少是1:1001:1000更好(上述状态值可以使用SHOW STATUS LIKE 'key_read%'获得)。注意:该参数值设置的过大反而会是服务器整体效率降低

    ft_min_word_len = 4
    # 分词词汇最小长度,默认4

    transaction_isolation = REPEATABLE-READ
    # MySQL支持4种事务隔离级别,他们分别是:
    # READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.
    # 如没有指定,MySQL默认采用的是REPEATABLE-READORACLE默认的是READ-COMMITTED

    log_bin = mysql-bin
    binlog_format = mixed
    expire_logs_days = 30 #超过30天的binlog删除

    log_error = /data/mysql/mysql-error.log #错误日志路径
    slow_query_log = 1
    long_query_time = 1 #慢查询时间 超过1秒则为慢查询
    slow_query_log_file = /data/mysql/mysql-slow.log

    performance_schema = 0
    explicit_defaults_for_timestamp

    #lower_case_table_names = 1 #不区分大小写

    skip-external-locking #MySQL选项以避免外部锁定。该选项默认开启

    default-storage-engine = InnoDB #默认存储引擎

    innodb_file_per_table = 1
    # InnoDB为独立表空间模式,每个数据库的每个表都会生成一个数据空间
    # 独立表空间优点:
    # 1.每个表都有自已独立的表空间。
    # 2.每个表的数据和索引都会存在自已的表空间中。
    # 3.可以实现单表在不同的数据库中移动。
    # 4.空间可以回收(除drop table操作处,表空不能自已回收)
    # 缺点:
    # 单表增加过大,如超过100G
    # 结论:
    # 共享表空间在Insert操作上少有优势。其它都没独立表空间表现好。当启用独立表空间时,请合理调整:innodb_open_files

    innodb_open_files = 500
    # 限制Innodb能打开的表的数据,如果库里的表特别多的情况,请增加这个。这个值默认是300

    innodb_buffer_pool_size = 64M
    # InnoDB使用一个缓冲池来保存索引和原始数据, 不像MyISAM.
    # 这里你设置越大,你在存取表里面数据时所需要的磁盘I/O越少.
    # 在一个独立使用的数据库服务器上,你可以设置这个变量到服务器物理内存大小的80%
    # 不要设置过大,否则,由于物理内存的竞争可能导致操作系统的换页颠簸.
    # 注意在32位系统上你每个进程可能被限制在 2-3.5G 用户层面内存限制,
    # 所以不要设置的太高.

    innodb_write_io_threads = 4
    innodb_read_io_threads = 4
    # innodb使用后台线程处理数据页上的读写 I/O(输入输出)请求,根据你的 CPU 核数来更改,默认是4
    # :这两个参数不支持动态改变,需要把该参数加入到my.cnf里,修改完后重启MySQL服务,允许值的范围从 1-64

    innodb_thread_concurrency = 0
    # 默认设置为 0,表示不限制并发数,这里推荐设置为0,更好去发挥CPU多核处理能力,提高并发量

    innodb_purge_threads = 1
    # InnoDB中的清除操作是一类定期回收无用数据的操作。在之前的几个版本中,清除操作是主线程的一部分,这意味着运行时它可能会堵塞其它的数据库操作。
    # MySQL5.5.X版本开始,该操作运行于独立的线程中,并支持更多的并发数。用户可通过设置innodb_purge_threads配置参数来选择清除操作是否使用单
    # 独线程,默认情况下参数设置为0(不使用单独线程),设置为 1 时表示使用单独的清除线程。建议为1

    innodb_flush_log_at_trx_commit = 2
    # 0:如果innodb_flush_log_at_trx_commit的值为0,log buffer每秒就会被刷写日志文件到磁盘,提交事务的时候不做任何操作(执行是由mysqlmaster thread线程来执行的。
    # 主线程中每秒会将重做日志缓冲写入磁盘的重做日志文件(REDO LOG)中。不论事务是否已经提交)默认的日志文件是ib_logfile0,ib_logfile1
    # 1:当设为默认值1的时候,每次提交事务的时候,都会将log buffer刷写到日志。
    # 2:如果设为2,每次提交事务都会写日志,但并不会执行刷的操作。每秒定时会刷到日志文件。要注意的是,并不能保证100%每秒一定都会刷到磁盘,这要取决于进程的调度。
    # 每次事务提交的时候将数据写入事务日志,而这里的写入仅是调用了文件系统的写入操作,而文件系统是有 缓存的,所以这个写入并不能保证数据已经写入到物理磁盘
    # 默认值1是为了保证完整的ACID。当然,你可以将这个配置项设为1以外的值来换取更高的性能,但是在系统崩溃的时候,你将会丢失1秒的数据。
    # 设为0的话,mysqld进程崩溃的时候,就会丢失最后1秒的事务。设为2,只有在操作系统崩溃或者断电的时候才会丢失最后1秒的数据。InnoDB在做恢复的时候会忽略这个值。
    # 总结
    # 设为1当然是最安全的,但性能页是最差的(相对其他两个参数而言,但不是不能接受)。如果对数据一致性和完整性要求不高,完全可以设为2,如果只最求性能,例如高并发写的日志服务器,设为0来获得更高性能

    innodb_log_buffer_size = 2M
    # 此参数确定些日志文件所用的内存大小,以M为单位。缓冲区更大能提高性能,但意外的故障将会丢失数据。MySQL开发人员建议设置为18M之间

    innodb_log_file_size = 32M
    # 此参数确定数据日志文件的大小,更大的设置可以提高性能,但也会增加恢复故障数据库所需的时间

    innodb_log_files_in_group = 3
    # 为提高性能,MySQL可以以循环方式将日志文件写到多个文件。推荐设置为3

    innodb_max_dirty_pages_pct = 90
    # innodb主线程刷新缓存池中的数据,使脏数据比例小于90%

    innodb_lock_wait_timeout = 120 
    # InnoDB事务在被回滚之前可以等待一个锁定的超时秒数。InnoDB在它自己的锁定表中自动检测事务死锁并且回滚事务。InnoDBLOCK TABLES语句注意到锁定设置。默认值是50

    bulk_insert_buffer_size = 8M
    # 批量插入缓存大小, 这个参数是针对MyISAM存储引擎来说的。适用于在一次性插入100-1000+条记录时, 提高效率。默认值是8M。可以针对数据量的大小,翻倍增加。

    myisam_sort_buffer_size = 8M
    # MyISAM设置恢复表之时使用的缓冲区的尺寸,当在REPAIR TABLE或用CREATE INDEX创建索引或ALTER TABLE过程中排序 MyISAM索引分配的缓冲区

    myisam_max_sort_file_size = 10G
    # 如果临时文件会变得超过索引,不要使用快速排序索引方法来创建一个索引。注释:这个参数以字节的形式给出

    myisam_repair_threads = 1
    # 如果该值大于1,在Repair by sorting过程中并行创建MyISAM表索引(每个索引在自己的线程内

    interactive_timeout = 28800
    # 服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。默认值:28800秒(8小时)

    wait_timeout = 28800
    # 服务器关闭非交互连接之前等待活动的秒数。在线程启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,
    # 取决于客户端类型(mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义)。参数默认值:28800秒(8小时)
    # MySQL服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此我们希望客户端在连接到MySQL Server处理完相应的操作后,
    # 应该断开连接并释放占用的内存。如果你的MySQL Server有大量的闲置连接,他们不仅会白白消耗内存,而且如果连接一直在累加而不断开,
    # 最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误。对于wait_timeout的值设定,应该根据系统的运行情况来判断。
    # 在系统运行一段时间后,可以通过show processlist命令查看当前系统的连接状态,如果发现有大量的sleep状态的连接进程,则说明该参数设置的过大,
    # 可以进行适当的调整小些。要同时设置interactive_timeoutwait_timeout才会生效。

    [mysqldump]
    quick
    max_allowed_packet = 16M #服务器发送和接受的最大包长度

    [myisamchk]
    key_buffer_size = 8M
    sort_buffer_size = 8M
    read_buffer = 4M
    write_buffer = 4M

     


    展开全文
  • IntelliJ IDEA 的实时代码模板保存在/templates目录下,其他系统目录位置如下:(因为目录名在各个系统上是一致的,建议用硬盘搜索工具搜索即可) Windows:. Linux: ~/./config/templates OS X: ~/Library/...
    • IntelliJ IDEA 的实时代码模板保存在 /templates 目录下,其他系统目录位置如下:(因为目录名在各个系统上是一致的,建议用硬盘搜索工具搜索即可)
    • Windows: .
    • Linux: ~/./config/templates
    • OS X: ~/Library/Preferences//templates

    转载于:https://www.cnblogs.com/huhuixin/p/6806800.html

    展开全文
  • Tomcat目录结构及配置文件

    千次阅读 2018-04-20 11:16:35
    TOMCAT的目录结构/bin:存放windows或Linux平台上启动和关闭Tomcat的脚本文件/conf:存放Tomcat服务器的各种全局配置文件,其中最重要的是server.xml和web.xml/doc:存放Tomcat文档/server:包含三个子目录:classes...
  • 用户和组相关的配置文件1.1. /etc/passwd 文件 (1行7列)1.2. /etc/shadow 文件(1行9列)1.3. /etc/group 文件(1行4列)1.4. /etc/gshdow 文件(1行4列)1.5. 总结4个文件`/etc/passwd`文件格式 一共7列:`/etc/...
  • Windows下的用户配置文件管理(一)

    千次阅读 2017-11-17 15:27:00
    用户配置文件定义保存了用户的工作环境。根据工作环境的不同,Windows支持三种类型配置文件: 本地用户配置文件 漫游用户配置文件 强制用户配置文件 另外,系统还提供了默认本地配置文件、默认域配置文件的支持。 ...
  • 登录保存回显用户信息或配置文件(sharedpreferences) 目录  登录保存回显用户信息或配置文件(sharedpreferences)  1.项目目录结构 二、类:MainActivity 三、类:activity_main.xml  1.项目目录结构   ...
  • 简介:在linux中用户及用户组的配置都由文本文件记录保存:一下文件保存了基本的用户创建默认配置,用户配置,组配置 说明 文件 创建用户是相关的变量 /etc/default/useradd 用户与组的默认设置 /etc/login....
  • Oracle 配置文件目录

    千次阅读 2018-08-17 18:59:00
    Oracle 配置文件目录 ① 在oracle安装目录下,找D:\oracle\product\10.2.0\client_1\NETWORK\ADMIN中的tnsnames.ora文件,找到之后,配置相关属性 ② tnsnames.ora文件修改内容。 TOUGU= --(备注:Databasename...
  • mysql安装目录配置文件存放位置

    千次阅读 2015-09-28 10:44:07
    linux系统下,如何知道mysql使用的配置文件到底是哪个呢?linux自带的mysql的安装目录又是什么呢?数据存放在什么目录下? 1、linux系统自带的mysql,其安装目录及数据目录查看方法(前提是已启动mysql服务):...
  • openwrt各种默认配置文件所在目录

    千次阅读 2018-07-03 08:50:30
    from: ...1.wifi的默认开启方式、ssid、加密方式等配置package/kernel/mac80211/files/lib/wifi/mac80211.sh 122.硬件资源的配置(usb、gpio、flash等)...
  • C# 保存和读取XML配置文件

    千次下载 热门讨论 2008-12-20 13:50:18
    应用程序中,经常需要保存一些用户的设置,所以就需要把这些设置保存到一个配置文件中,以便随时读取和写入。 这个代码就是用C#写的保存和读取程序运行目录下的XML配置文件的程序,配置文件也会自动生成,很灵活的。...
  • 漫游用户配置文件方法

    千次阅读 2017-02-06 10:24:17
    漫游用户配置文件的作用是无论用户登录到哪台基于 Microsoft Windows NT 的计算机上,漫游用户配置文件都为用户提供相同的工作环境。这样就可以避免因为换了机器而丢失以前的作用环境而不爽了,也不会降低工作质量。...
  • 修改Pycharm的配置文件存放位置

    万次阅读 2020-03-07 02:07:49
    修改 pycharm 的配置文件存放位置 Pycharm 配置文件默认是放在C盘的,修改存放位置,这样系统重装的时候就不会不见了。 找到你Pycharm 的安装目录,进入bin目录,找到idea.properties文件打开。 去掉下面这两行...
  • 修改firefox用户配置文件

    千次阅读 2018-05-15 10:37:38
    Firefox 将您的个人信息(例如书签、密码和首选项)保存在一系列文件中,它们被叫做用户配置文件,它们与 Firefox 的程序文件保存在不同位置。您可以拥有多个用户配置文件,每个用户配置文件可以包含不同的用户信息...
  • Firefox 将用户个人信息(例如书签、密码、首选项、扩展、Cookie、证书等)保存在一系列文件中,它们被叫做用户配置文件,它们与 Firefox 的程序文件保存在不同位置。 因此,WebDriver如果能够加载已有的FireFox用户...
  • 【Linux】 Apache配置文件详解

    千次阅读 2020-07-25 21:58:54
    修改配置文件 [root@gaosh-64 ~]# vim /etc/httpd/conf/httpd.conf 31 ServerRoot "/etc/httpd" #apache配置文件的根目录 32 Timeout 60 #添加此项,超时时间 42 Listen 80 #监听的端口 改:86 ServerAdmin ...
  • 用户配置文件/etc/passwd和密码配置文件/etc/shadow详解
  • Linux配置文件路径大全

    万次阅读 2016-06-20 23:59:04
    Linux配置文件路径大全 1:/etc/sysconfig/i18n(语言配置文件).2:/etc/sysconfig/network-scripts/ifcfg-eth0(eth0配置文件). 3:/boot/grub/grub.conf(grup配置文件) 或/boot/grub/menu.list. 4:/etc/passwd:系统...
  •   &...修改本地临时文件存储目录及Hadoop配置文件说明 1、 修改本地临时文件存储目录 1.1、停止进程 [admin@hadoop12 hadoop-2.7.2]$ sbin/yarn-daemon.sh stop nodemanager
  • jenkins配置文件目录

    万次阅读 2017-01-16 13:35:15
    jenkins配置默认会存放用户目录下的.jenkins文件夹中,如test用户[root@iZ232zv25vtZ ~]# cd /home/test/.jenkins
  • 用户目录下设置 .vimrc 配置文件

    千次阅读 2016-03-03 23:27:59
    首先在用户目录下执行指令 ls -a  查看所有文件(包括隐藏文件) 如果没有 .vimrc文件 ,可以新建一个,然后用 vim 编辑: set nocp set ru syntax on set number set tabstop=4 set autoindent set ...
  • mysql 在配置文件保存密码

    千次阅读 2019-07-04 14:31:47
    mysql 在配置文件保存密码 打开配置文件 nano /etc/my.cnf 添加 [client] host=localhost user=root password='123456'
  • Linux用户和群组管理的主要配置文件

    千次阅读 2017-07-23 19:45:07
    Linux 用户 Linux组 配置文件 /etc/passwd /etc/shadow /etc/group /etc/gshadow /etc/default/useradd /etc/skel/* /etc/login.defs
  • 更改Pycharm的配置文件存放位置

    千次阅读 2021-05-05 16:01:50
    最近发现我的C盘的可用空间越来越小了,就想清除C盘中的无用内存。...1、修改 pycharm 的配置文件存放位置 Pycharm 配置文件默认是放在C盘的,修改存放位置,这样系统重装的时候就不会不见了。 找到
  • Chrome 用户数据配置文件夹保存路径

    千次阅读 2019-09-18 15:24:20
    但是除了一些玩 Chrome 很长时间的用户,鲜有人知道 Chrome 的用户数据到底保存在什么地方。如果你也有这样的需求,不妨记下下面的这些路径: Mac OS X: ~/Library/Application Support/Google/Chrome/Default ...
  • Dbeaver6.2.4配置文件变动(windows)

    千次阅读 2019-11-12 11:54:08
    Dbeaver的配置文件一直都存放在C盘的指定位置(用户目录下),这样在每次更新Dbeaver的时候可以完美迁移配置文件过来,但是这次从dbeaver6.0.2升到6.2.4的时候却发现配置文件没有迁移过来,在网上查资料也没有查到...
  • 一、配置文件 配置文件默认分为3个部分 [root@XY-PC ~]# grep ‘<Section>’ /etc/httpd/conf/httpd.conf -Hn /etc/httpd/conf/httpd.conf:33:### Section 1: Global Environment /etc/httpd/conf/...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 1,161,585
精华内容 464,634
关键字:

哪个目录存放用户配置文件