• hua168
    2019-01-19
    大神,能问一个题外话吗,关于自己人生规划,水平和眼界所限,想不通,
    都说大神级见识很广也多,能给我这个35岁只维护过四五十台linux服务器的运维指条路吗?
    现在很迷茫和压力大~~
    能力如下:
    一.网络:CCNA水平,自过了CCNP忘记了,当过2年网管
    二、维护过asp.net电商网站,3年,只有简单的,兼职网管
    三、linux运维,只在一家电商做了3年多,会
    1.web:nginx、tomcat配置(少用)+php:nignx的rewirte和反代
    2.数据库:mysql、mongoDB、redis 配置及主从,不会mycat、Cetus之类
    3.反代:会nginx、haproxy简单配置
    4.存储:NFS、fastDFS、hadoop简单看了一下
    5.版本控制:只会git及搭建gitlab+jenkins(简单的CI/CD)
    6.监控:简单配置zabbix+shell脚本
    7.虚拟化:kvm安装及配置、docker(k8s还没学)
    8.云计算:openstack只会安装做过实验
    9.测试:只会ab工具
    10.日志:ELK安装配置,还没结合java(在学中)
    11.大数据:没使用过(不会flume、storm、spark、flink、kafka)
    12.脚本:主要是shell为主、会点python

    四、编程能力:自学,没项目经验
    1.前端:
      1)HTML(HTML5不怎看)
      2)css(laiui、学了一下vue)
      3) js、jquery框架、ES6简单看了一下
    2.PHP:语法简单的thinkphp5框架
    3.java:考虑要维护java web在学
        只看了java、jsp及servet、spring、springMVC、spring Boot(这个为主)
    4.python:考虑运维用到
        python:会简单的脚本
        django:只会官网简单的
        
    问题是:现在已35岁了,失业,怎办?年龄摆在那里,能力好像不强,学历大专。
    能给个建议吗?非常感谢~~
    展开

    作者回复: 看前面的经历,技术面还是挺广的,但可能很多地方都不太深入。

    建议还是先找份工作吧,长期待业可能会加重焦虑。然后可以根据实际工作需要,先把工作需要的知识技能加深掌握。等到可以从容应对工作的时候,再考虑在某个领域加强深入。

     3
     42
  • Christmas
    2019-01-18
    pcstat(page cache stat)这个可以查看目标log文件在cache中的大小

    作者回复: 嗯嗯 是的,并且这个工具需要知道哪个文件

    
     14
  • 划时代
    2019-01-18
    指出老师的一个问题,“日志回滚文件”,打印日志的过程中从直觉来看很容易误认为日志是在“回滚”,我也犯过这样的错误;rotating英文直译为“旋转”或“轮流”,实际的日志打印过程中,日志名称是“旋转”的,例如log.1(当前打印的日志文件并且一直会打印这个文件),log.2(较早日志),log.3(更早日志),当触发“旋转”条件时,日志名称会发生变更,假如log.3是上限数,那么log.3发生“旋转”就被remove,log.2被rename为log.3。更形象一点的描述是,日志名称发生了滚动,log.1=>log.2=>log.3不断的更新。

    作者回复: 谢谢指出,确实只是文件名称的旋转,内容并没有回滚

    
     10
  • 无名老卒
    2019-01-22
    查看buffer/cache占用,建议使用pcstat或者hcache,hcache是基于pcstat的,pcstat可以查看某个文件是否被缓存和根据进程pid来查看都缓存了哪些文件。hcache在其基础上增加了查看整个操作系统Cache和根据使用Cache大小排序的特性。

    [root@linjx ~]# hcache --top 3
    +--------------------------+----------------+------------+-----------+---------+
    | Name | Size (bytes) | Pages | Cached | Percent |
    |--------------------------+----------------+------------+-----------+---------|
    | /usr/bin/containerd | 44250880 | 10804 | 10804 | 100.000 |
    | /usr/bin/dockerd-ce | 81622264 | 19928 | 8319 | 041.745 |
    | /usr/bin/containerd-shim | 4972896 | 1215 | 1215 | 100.000 |
    +--------------------------+----------------+------------+-----------+---------+
    展开
    
     9
  • 郭江伟
    2019-01-18
    buffers/cached使用情况可以从proc文件系统看:
    gjw@gjw:~$ cat /proc/meminfo
    MemTotal: 7588504 kB
    MemFree: 3621800 kB
    MemAvailable: 6335912 kB
    Buffers: 473920 kB
    Cached: 2491192 kB
    展开
    
     8
  • 我来也
    2019-01-18
    [D26打卡]
    又是老套路了,哈哈。
    先是top看%iowait到升高,再看pidstat是哪个进程在操作磁盘,再strace看进程的调用栈。
    看/proc/meminfo就可以看到系统的buffer和cache各占了多少吧。前后一对比就知道是谁了。😄
    
     7
  • J
    2019-01-20
    logger.info(message)的情况下,还可以使用logger.setLevel修改日志级别吗?

    作者回复: 可以的,比如调高到警告级别,那么 info() 实际上就不写了

    
     2
  • 小老鼠
    2019-01-20
    我觉的应该是cache,写日志,日志是文件
    
     2
  • Geek_41dcba
    2019-01-18
    在回答今天的思考题前,我想需要明确两个前提,一个是Buffer到底在整个系统结构的哪一层,会不会是不是在IO调度器的下一层,我想应该会,理由是Buffer缓存磁盘内容调度器合并后再去写磁盘效率更好;另一个是之前有看到留言对于文件系统使用带Cache的IO操作底层为了性能Buffer和Cache是合并的,如果是这样那我就从逻辑上认为它们是分开的,这样好回答问题(声明我没看过底层代码都是没有代码依据的)。 我认为增长的地方都在Buffer里面,Cache里面的内容可以经过IO调度器整理后放Buffer,没有理由说磁盘阻塞,Cache就不能移动到Buffer 查看数据的地方在/proc/meminfo。

    上面的都想法今天没有时间验证,要明天了!
    展开

    作者回复: 嗯 可以实际操作验证一下

    
     2
  • wtcctw
    2019-01-18
    逻辑清晰,步骤详细,赞
    
     2
  • 张洁
    2019-10-17
    老师,你好。测试中遇到的情况跟你说的不太一样。
    iostat -d -x 1得到的结果
    %util达到99%,IOPS 90,吞吐量 700KB/S,响应时间 10ms,平均等待队列1.1;
    top 看到iowait 30%,不到60%;
    并发数增加,cpu、内存使用率都没有增加,磁盘使用率99%;
    如何判断出磁盘是否已经达到了饱和?对于这个结果,我不能分析出磁盘是否达到了瓶颈。
    是否可以指点下?可否利用磁盘最大的IOPS来判断是否磁盘达到了瓶颈?谢谢!
    展开
    
     1
  • 小苏
    2019-08-18
    strace -p 18923
    Process 18923 attached
    futex(0x7fbe2c2e39d0, FUTEX_WAIT, 18924, NULL
    我好像对每个进程执行该命令都会卡在这地方.这个命令基本上用不上,不知道怎么回事.
    
     1
  • Hinimix
    2019-07-19
    老师,代码里怎么写能接受sigusr这个参数呢,现在每次改级别我都是改配置文件然后重启

    作者回复: 不同编程语言都有相应的库函数可以调用。案例中Python的使用方法可以参考https://github.com/feiskyer/linux-perf-examples/blob/master/logging-app/app.py#L47

     1
     1
  • 小肥皂酱
    2019-04-12
    老师,我运行docker run -v /tmp:/tmp --name=app -itd feisky/logapp 这个命令几秒后这个进程就不在了。怎么回事呢

    作者回复: 应该是退出了,docker logs app看看是什么错误信息

     1
     1
  • 安小依
    2019-01-18
    Ubuntu 16.04, 使用 strace 应该需要先临时修改系统一个配置:echo 0 | sudo tee /proc/sys/kernel/yama/ptrace_scope。另外用 java 模拟写文件,strace 发现还是不行,一直卡在这个地方:

    zk@zk-pc:~/Documents$ strace -p 6526
    strace: Process 6526 attached
    futex(0x7f934a93a9d0, FUTEX_WAIT, 6527, NULL

    老师帮忙看一下,Java 源代码如下。注释掉的部分 System.out 是疯狂打日志 (标准输出),线上环境出现过,疯狂 println 结果磁盘打满的问题,想模拟一下,结果发现不行。然后换成了写文件,结果 strace 还是看不出来,卡在那个地方一直不动:

        public static void main(String...args) throws Exception {
            File file = new File("/tmp/aaa");
            PrintWriter printWriter = new PrintWriter(file);

            while (true) {
                printWriter.write(UUID.randomUUID().toString());
                // System.out.println("------------------------------NULL-------------------");
                LockSupport.parkNanos(1);
            }
        }

    另外问一下老师,一直向标准输出打印的话,最终的那个文件是放在哪里呢了?怎么就把磁盘打满了呢?
    展开

    作者回复: 你这个例子是向文件 /tmp/aaa 写,不是标准输出

    
     1
  • 汤🐠🥣昱
    2019-10-22
    老师,我用linux的一个1核的 内存1G的服务器,没有出现io瓶颈的问题,通过top命令到是发现了cpu使用率飚到93%,64.5 us, 29.2 sy。这是是trace跟踪的情况:怎么反应不了是io的问题尼?
    mmap(NULL, 393220096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = -1 ENOMEM (Cannot allocate memory)
    munmap(0x7f2cc8098000, 314576896) = 0
    write(2, "--- Logging error ---\n", 22) = 22
    stat("/usr/local/lib/python3.7/logging/handlers.py", {st_mode=S_IFREG|0644, st_size=57674, ...}) = 0
    write(2, "Traceback (most recent call last"..., 35) = 35
    write(2, " File \"/usr/local/lib/python3.7"..., 108) = 108
    write(2, " File \"/usr/local/lib/python3.7"..., 122) = 122
    write(2, "MemoryError\n", 12) = 12
    write(2, "Call stack:\n", 12) = 12
    stat("/app.py", {st_mode=S_IFREG|0664, st_size=1289, ...}) = 0
    write(2, " File \"/app.py\", line 52, in <m"..., 63) = 63
    write(2, " File \"/app.py\", line 43, in wr"..., 65) = 65
    mmap(NULL, 314576896, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f2cc8098000
    mmap(NULL, 393220096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = -1 ENOMEM (Cannot allocate memory)
    munmap(0x7f2cc8098000, 314576896) = 0
    write(2, "Unable to print the message and "..., 119) = 119
    select(0, NULL, NULL, NULL, {0, 100000}) = 0 (Timeout)
    getpid() = 1
    mmap(NULL, 314576896, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f2cc8098000
    mmap(NULL, 393220096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = -1 ENOMEM (Cannot allocate memory)
    munmap(0x7f2cc8098000, 314576896) = 0
    write(2, "--- Logging error ---\n", 22) = 22
    stat("/usr/local/lib/python3.7/logging/handlers.py", {st_mode=S_IFREG|0644, st_size=57674, ...}) = 0
    write(2, "Traceback (most recent call last"..., 35) = 35
    write(2, " File \"/usr/local/lib/python3.7"..., 108) = 108
    write(2, " File \"/usr/local/lib/python3.7"..., 122) = 122
    write(2, "MemoryError\n", 12) = 12
    write(2, "Call stack:\n", 12) = 12

    展开
    
    
  • Shane
    2019-10-20
    老师,我今天才看完这篇文章。想要提几个问题,不知道该专栏过了这么长时间了,还会不会被老师看到。不过还是提着把,万一看到并且回复了呢?

    有一点困惑难以理解?在运行app.py命令之后,使用top查看时,发现cpu的wait使用率在80,90徘徊。

    但是top下面的python进程的cpu使用率只有6%。

    在我的理解中,现在总的cpu使用率是1 - idle。也就是90%左右。其中大量都是wait,sys之占用了6%左右。

    但是,top下面所有进程的使用率总和不是应该是1-idle,90%左右吗?难道所有的进程的cpu使用率的总和和上面的不是相等的吗?

    如果不是相等的,我还想到了一种可能是: 进程显示的是所有cpu的使用率,某一个进程的使用率应该会超过100%(如果有多个逻辑核心)。还是不应该出现总和小于上面的总cpu使用率的情况吧??

    希望老师答疑解惑。
    展开

    作者回复: 请参考 05 篇,有对这个问题的详细讲解

    
    
  • 烨
    2019-08-20
    老师你好,make init后一直报错连不上mysql是为啥呢?
    curl http://127.0.0.1:10000/db/insert/products/10000后报错:
    pymysql.err.OperationalError: (2003, &quot;Can't connect to MySQL server on '127.0.0.1' ([Errno 111] Connection refused)&quot;)
    实际是起来了的

    作者回复: 可能mysql还没初始化好,重启一下mysql容器试试

    
    
  • 飞鸟
    2019-08-19
    老师好, 我前段时间我们生产集群 遇到过 jbd2引起IO过高,导致kudu 平均负载超载,严重影响正常的读写,当时我定位到了是 jbd2导致的, 可是我不知改咋办,最后无奈,停掉作业重启了Kudu。 对这个问题我不知改如何解决, 老师指点指点。
    
    
  • lisi
    2019-06-26
    cachetop
    
    
我们在线,来聊聊吧