zoukankan      html  css  js  c++  java
  • 详解高级PHP工程师面试题

    第1题.Git的分支你们是怎么管理的?

    git 为什么好,为什么要用 git,这不是我本文想要说明的问题。

    这里想要给大家分享一下自己使用过程中产生的疑惑,以及解决的这些疑惑的过程。话又说回来,我现在依然充满疑惑。真不知道30岁的时候会不会不惑。

    在使用 git 过程中,它的分支功能让我真的欣喜若狂,不过这是把双刃剑,一不小心你会得到这种git路径图:

    image

    图片来源:阮一峰老师博客

    我的疑惑:

    1. 那么团队中我们该使用怎样的分支策略来进行开发协作?

    2. 在多人的团队中,我们应该在 master 分支上直接开发吗?

    3. 如果线上产生了bug该通过什么样方式的分支去修复?

    4. 当有多个分支的时候,测试如何有效的参与进来每一个分支的测试?

    用成熟的工作流来解决问题

    在解答上面的疑惑前,先介绍几个工作流,然后通过工作流的模式,来进行解答。因为我们必须在某种设定的情景下,才能讨论解决问题的思路。

    下面三种工作流方式,都是采用功能驱动开发,也就是先有需求产生,然后诞生对应的分支,然后开发,最后合并回来,完成使命被删除。

    • Git flow

    • Github flow

    • Gitlab flow

    关于这三种工作流的详细介绍,建议看看这篇文章-阮一峰

    我现在采用的是 Git flow ,经过自己的实践,确实好用,解决不少问题。然后如果发现与自己的实际情况有些出入,可以根据需求做出些变动调整。

    我的选择

    我选择了 Git flow,它的主要特点是,长期存在两个分支:

    • 主分支master

    • 开发分支develop

    然后,存在三种辅助分支,都是短期的,并且一半情况下只应该存在本地,不要提交到远程库。

    • 功能分支(feature branch)

    • 补丁分支(hotfix branch)

    • 预发分支(release branch)
      在进行上面的分支时,建议的命名规范:feature-xxx、release-xxx、hotfix-xxx

    话外:我以前喜欢用下划线,后来发现打中线不需要按 shift ,哈哈,从此开始中线时代。

    什么时候要功能分支?

    当你拿到一个需求,或者不是一个立马需求上线的bug修复,那么就应该从 develop 开一个分支出来,完成这部分工作。完成后合并到 develop 分支。

    image

    什么时候要预发分支?

    这个分支是为预发准备的,测试的介入,也只应该在该分支产生时才介入。当我们不管是新功能开发,还是一般的bug修改都差不多了。就应该从develop产生一个release分支,交给测试,如果有bug直接在上面修改。全部完成后,合并回develop,并且合并到master

    关于这个分支我得再多说几句。因为这是非常重要的一步,如果我们使用了 git 钩子,当合并到 master 的时候,会自动发布到线上,所以这是临上线的最后一道屏障。

    同时这里也解决了我一个疑惑,测试如何参与到git的每个分支中来?答案是:测试不应该参与到每个分支中来,只应该参与到release分支中去。其它的开发分支,都应该由开发人员自己测试,测试没有问题的时候才准许合并到develop,这就要求每一个开发要提高自己交付的产品质量,如何确保自己交付的产品质量?自动化测试是个不错的选择,好了,打住,这不是咋们今天的主要任务,这个话题改天再聊。

    什么时候需要补丁分支?

    这种情况越少越好。因为它产生的原因是:线上出了bug,并且必须马上修复,不管你身在何方,当手机响起,拿出电脑改bug吧。

    它与release 很像,都需要完成后,同时合并到:masterdevelop。不同的是,它需要从master 上开一个分支出来。
    image

    注意这里没有测试的介入,一半来说都是代码上某一个小的紧急bug,虽然很严重,但是可以很容易改动。当然如果有一些例外情况,应该让测试进行测试后再合并、发布。

    总结

    git 开发很好用,但是要按照一定规则合理使用分支。

    另外,除了:masterdevelop 分支,其它分支都不应该出现在远程仓库中。

    git一定要结合它的各种钩子来使用,提升开发效率。这里后面来介绍下。

    参考资料:

    第2题. PHP进程间通信是如何实现的?

    通常linux中的进程通信方式有:消息队列、信号量、共享内存、信号、管道、socket。

    消息队列: 消息队列是存放在内存中的一种队列数据结构。

    信号量:是系统提供的一种原子操作,一个信号量,同时只有你一个进程能操作。一个进程获得了某个信号量,就必须被该进程释放掉。

    共享内存:是系统在内存中开辟的一块公共的内存区域,任何一个进程都可以访问,在同一时刻,可以有多个进程访问该区域,为了保证数据的一致性,需要对该内存区域加锁或信号量。

    信号: 信号是一种系统调用。通常我们用的kill命令就是发送某个信号给某个进程的。具体有哪些信号可以在liunx/mac中运行kill -l查看。下面这个例子中,父进程等待5秒钟,向子进程发送sigint信号。子进程捕获信号,掉信号处理函数处理。

    管道: 管道是比较常用的多进程通信手段,管道分为无名管道与有名管道,无名管道只能用于具有亲缘关系的进程间通信,而有名管道可以用于同一主机上任意进程。这里只介绍有名管道。下面的例子,子进程写入数据,父进程读取数据。

    我们发现 PHP 对信号量和共享内存封装得很好,使用起来非常简单。除此之外,PHP 的类库 Sync 将常用 IPC 方法封装成为类,能实现跨平台的使用.

    参考:PHP进程间通信详解  PHP进程间通信

    3. Swoole的协程和php自带的yield的场景有哪些?

    php自带的yield的场景:

    协程可以用在,异步网络 IO 的时候,使其成为非阻塞的。

    比如你在一个 http 请求里面,你需要请求外面的接口,那么会有下面的场景。

    你的前置 server 是 nginx,nginx 是非阻塞异步的,但是 php-fpm 是同步阻塞的。那么当你在请求外面接口的时候,这个任务就会被阻塞。(这里补充一下,php-fpm 的 Worker 进程是同步阻塞的)

    假设你使用协程,那么当你在请求接口的时候,你的这个任务就可以暂停,保存上下文。然后呢,当你的接口返回了之后,重新调起这个任务继续执行。你的进程就不必耗在这一个任务上了,可以去处理其它的 http 请求了。这样是不是并发量就高了?

    同理,当你的请求在查询数据库的时候,也是一个 IO 请求,也是同步的。协程就可以让你这些 IO 编程异步非阻塞的,从而增大你的并发量。这主要是让你的 CPU 可以在等待 IO 的时候,可以处理别的事情。所有的 IO 请求都可以通过协程做到这一点。

    4.搭建MySQL分布式有哪些方式?

    5.什么是Hash一致性,这个方法主要运用在什么场景

  • 相关阅读:
    java ->IO流_打印流
    java ->IO流_序列化流与反序列化流
    java ->properties类
    java ->String、StringBuffer、StringBuilder三者之间的区别
    java-> 利用IO操作与递归实现目录的复制
    java
    java ->IO流_转换流
    java ->IO流_字符流
    java ->IO流_字节流
    死循环
  • 原文地址:https://www.cnblogs.com/lxwphp/p/15453002.html
Copyright © 2011-2022 走看看