[关闭]
@garygchai 2017-01-16T09:33:06.000000Z 字数 2839 阅读 1784

yoda-xiss项目说明

阿里


国际信息流运营后台yoda-xiss项目说明

下载

$ git clone git@gitlab.alibaba-inc.com:NewBee/yoda-xiss.git

安装

启动

package.json文件已经在scripts中定义启动命令,直接启动即可:$ npm run dev

ps: windows用户可能无法通过npm run dev完整地启动项目,因为windows命令控制台不认识&,那么我们可以分别启动,比如:先启动$ npm run dev(启动项目),再新开一个命令窗口启动$ npm run dev:yoda(运行webpack)

访问

启动之后就可以通过http://localhost:5000/访问yoda运营后台。

调试

新来的童鞋想尽快熟悉和上手项目代码,调试工具很重要,不然看一行行看源码真的好累,效率还不高。下面介绍几种调试方式。

这种方式最简单,简单的调试可以使用,但是运行复杂的项目就有点蛋疼,效率太低。

这种方式如果不借助其他工具,只支持前端代码调试,不支持后端代码,但是我们运营后台这么多nodejs的后端代码,怎么能没有调试呢,这种方式也不太靠谱。

这是一款很强大的调试工具,主要是借助chrome来做实现nodejs代码的调试。

不熟悉的童鞋先看一下node-inspector的教程
首先,启动一个node-inspector服务 $ node-inspector &
然后,启动项目文件 $ node --debug-brk app/index.js
或者,用一条命令代替上面两条命令 $ node-debug app/index.js

然后打开chrome通过http://127.0.0.1:8000/?port=5858访问调试代码。

当然,egg的启动调试远没这么简单,因为egg会启动3个进程,分别是masteragentworker

指定port=5858只能调试master进程的代码,因为master进程默认监听5858端口。
如果要调试agent进行的代码,需要打开http://127.0.0.1:8000/?port=5856进行调试,因为agent进程启动指定的是5856端口。
调试worker进程则要访问http://127.0.0.1:8000/?port=5859

如果对egg的启动原理感兴趣,可以去读读egg的源码,或者看看别人的分析吧:egg 源码学习

了解了上面几种调试方式,是不是还是觉得很难用呢!?下面介绍终极武器——vscode

  1. 打开vscode,点击调试(就是长得很像蜘蛛的那个按钮),切换到调试界面
  2. 点击打开launch.json,如果第一次打开就会生成一份launch.json文件
  3. 编辑launch.json配置文件
  1. {
  2. // Use IntelliSense to learn about possible Node.js debug attributes.
  3. // Hover to view descriptions of existing attributes.
  4. // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
  5. "version": "0.2.0",
  6. "configurations": [
  7. {
  8. "name": "Start Egg",
  9. "type": "node",
  10. "request": "launch",
  11. "program": "${workspaceRoot}/app/index.js",
  12. "cwd": "${workspaceRoot}",
  13. "runtimeArgs": [
  14. "--debug"
  15. ],
  16. "port": 5858
  17. },
  18. {
  19. "name": "Attach Agent",
  20. "type": "node",
  21. "request": "attach",
  22. "port": 5856
  23. },
  24. {
  25. "name": "Attach Worker",
  26. "type": "node",
  27. "request": "attach",
  28. "port": 5859
  29. }
  30. ],
  31. "compounds": [
  32. {
  33. "name": "Debug Egg",
  34. "configurations": ["Start Egg", "Attach Agent", "Attach Worker"]
  35. }
  36. ]
  37. }

如果遇到相关问题,可以参考一下这篇文章:使用 vscode@1.6 断点调试 egg cluster

eslint安装

项目代码规范通过eslint检查,如果代码不符合eslint规范,则无法提交。如果不借助工具,我们的编码的过程中很难保证每一行代码都符合规范,如果等到提交代码的时候再去修正代码错误,那将会非常的痛苦,简直是噩梦。下面我们来学习一下两大主流编辑器eslint的安装。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注