Windows环境下编译Flink文档

环境准备

  1. 安装Docker for Windows

    安装方法可以参考Docker官方文档,跟着文档一步一步走应该没什么问题的,我的是win10 家庭版的

  2. 安装Cygwin

    直接到官网下载安装即可:cygwin

  3. 下载flink源码

    git clone https://github.com/shizhengchao/flink.git,因为我fork到我自己的仓库,所以用的是我自己的地址,以便后面为社区做贡献

开始编译

  1. 打开Cygwin,进到flink/docs目录下执行 ./docker/run.sh命令

    $ ./docker/run.sh
    
  2. 如果上面的命令执行成功,那么应该是进入到了docker容器内部,在容器内部找到对应的flink目录,执行build_docs.sh脚本

    $ ./build_docs.sh -p
    
  3. 如果以上步骤都没有问题,那么会出现如下信息:

    -------------------------------------------------------------------------------------
    Configuration file: /opt/flink/_config.yml
                Source: /opt/flink
           Destination: /opt/flink/content
     Incremental build: disabled. Enable with --incremental
          Generating...
                        done in 106.278 seconds.
     Auto-regeneration: enabled for '/opt/flink'
        Server address: http://0.0.0.0:4000/
      Server running... press ctrl-c to stop.
    

    浏览器中输入:localhost:4000,就可以看到编译后的文档了,可以切换中英文。

问题汇总

基本上在windows环境下,按照上面的操作是成功不了的,以下是我遇到的几个问题:

  1. $'\r': command not found
    cygwin中输入 cd; pwd

    cd; pwd
    

    然后编辑.bash_profile,在末尾加上如下内容,重启cygwin

    export SHELLOPTS
    set -o igncr
    
  2. windows用户名是数字引发的问题

    groupadd: '0229' is not a valid group name
    

    导致这个问题的原因是我的windows用户是数字(公司的电脑,用户是工号),在run.sh中把 username改成英文名就行了,随便一个,我的是shizc, 在run.sh改成如下内容:

    if [ "$(uname -s)" == "Linux" ]; then
      USER_NAME=${SUDO_USER:=$USER}
      USER_ID=$(id -u "${USER_NAME}")
      GROUP_ID=$(id -g "${USER_NAME}")
    else # boot2docker uid and gid
      USER_NAME='shizc'
      USER_ID=$(id -u)
      GROUP_ID=$(id -g)
    fi
    
  3. cgywin中的磁盘目录挂载不了到docker容器中,报如下错误:

    the input device is not a TTY.  If you are using mintty, try prefixing the command with 'winpty'
    

    这个问题,网上给出的方案是在docker前面加上 winpty的命令,但是在我这不生效,识别不了winpty命令。在执行run.sh的时候,如果没有成功,会打印出执行的脚本语句:

    docker run -it --rm=true -w /cygdrive/d/java/flink/flink/docs/docker/.. -u shizc -v /cygdrive/d/java/flink/flink/docs/docker/..:/cygdrive/d/java/flink/flink/docs/docker/.. -p 4000:4000 flink/docs-shizc bash -c '
    echo
    echo '\''Welcome to Apache Flink docs'\''
    echo '\''To build, execute'\''
    echo '\''  ./build_docs.sh'\''
    echo '\''To watch and regenerate automatically'\''
    echo '\''  ./build_docs.sh -p'\''
    echo '\''and access http://localhost:4000'\''
    echo
    bash
    '
    the input device is not a TTY.  If you are using mintty, try prefixing the command with 'winpty'
    

    如上。把docker run 那段内容拷贝到powershell里执行, 并且修改成windows的目录格式 ,如下:

    docker run -it --rm=true -w /opt/flink/docs/docker/.. -u shizc -v d:/java/flink/flink/docs/docker/..:/opt/flink/docs/docker/.. -p 4000:4000 flink/docs-shizc bash
    

    如果报the working directory 'xxx is invalid, 则可以把-w xxxx,这段内容去掉,也就是不指定工作目录,也是可以的。

  4. 在powershell里执行后,会进入docker容器,然后在容器中运行 build_docs.sh脚本,如下:

    [shizc@5a9b5474c0b3 docs]$ ./build_docs.sh -p
    

    不出意外,第一次执行的话会报:No such file or directory,这个是因为脚本不是unix格式:

    首先用vim打开 build_docs.sh文件,然后 shift + :打开命令模式,输入 set ff , 回车,出现如下信息

    fileformat=dos
    

    可以看到 fileformat是dos格式,再次进入命令模式输入: set ff=unix,保存并退出vim ,再次执行build_docs.sh脚本。如果出现如下信息,则编译成功:

    Bundle complete! 9 Gemfile dependencies, 39 gems now installed.
    Bundled gems are installed into `./.rubydeps`
    Configuration file: /opt/flink/docs/_config.yml
                Source: /opt/flink/docs
           Destination: /opt/flink/docs/content
     Incremental build: disabled. Enable with --incremental
          Generating...
                        done in 109.813 seconds.
     Auto-regeneration: enabled for '/opt/flink/docs'
        Server address: http://0.0.0.0:4000/
      Server running... press ctrl-c to stop.
    

恭喜你已经完成了将为社区做贡献的第一步,打开浏览器,输入localhost:4000,看下哪些文档还没被翻译成中文的,赶紧到flink官方jira上提issue, 然后开始你的第一个 pr。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342