链接文件夹会产生奇怪的结果

时间:2017-12-12 18:55:27

标签: node.js laravel capistrano

我想了解linked_dirs的工作原理。我有以下作为例子

追加:linked_dirs,“storage”,“node_modules”,“vendor”,“public”

以上导致一些问题:

1:如果我在链接目录中保留“public”,则在初始部署时,公共文件夹会丢失git存储库中存在的大量文件。例如,如果没有在linked_dirs中列出“public”,我会在current / public中获得以下树:

[git@web003 current]$ ls -lh public/
total 52K
drwxrwxr-x  3 git git 4.0K Dec 12 16:48 custom
-rw-rw-r--  1 git git    0 Dec 12 16:48 favicon.ico
drwxrwxr-x  2 git git 4.0K Dec 12 16:48 fonts
drwxrwxr-x  4 git git 4.0K Dec 12 16:48 rsvp
drwxrwxr-x  2 git git 4.0K Dec 12 16:48 images
-rw-rw-r--  1 git git 2.7K Dec 12 16:48 index.php
-rw-rw-r--  1 git git 1.2K Dec 12 16:48 manifest.json
drwxrwxr-x  8 git git 4.0K Dec 12 16:48 maverick
-rw-rw-r--  1 git git   26 Dec 12 18:43 mix-manifest.json
drwxrwxr-x 15 git git 4.0K Dec 12 18:43 modules
-rw-rw-r--  1 git git   24 Dec 12 16:48 robots.txt
-rw-rw-r--  1 git git  781 Dec 12 16:48 serviceWorker.js
drwxr-xr-x  4 git git 4.0K Dec 12 18:43 vendor
-rw-rw-r--  1 git git  914 Dec 12 16:48 web.config

在linked_dirs中设置了“public”,我在current / public

中有以下目录树
[git@web003 public]$ ls -lh
total 12K
-rw-rw-r--  1 git git   26 Dec 12 17:16 mix-manifest.json
drwxrwxr-x 15 git git 4.0K Dec 12 17:16 modules
drwxr-xr-x  4 git git 4.0K Dec 12 17:16 vendor

有很多缺失,我不完全确定原因。另外mix_manifest.js是一个在我们运行一些编译脚本时生成和更新的文件,我希望它可以共享,但似乎我无法将它添加到linked_files,因为在初始部署时它不存在并且它返回一个错误:

00:02 deploy:check:linked_files       xxx上不存在ERROR链接文件/var/www/xxx/shared/public/mix-manifest.json

2:这与上面的node_modules

类似

如果我们在尝试运行npm run时共享node_modules ...它似乎无法找到某些文件,例如

npm run w-production // shortcut for:

cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js "--env.mixfile=build/w.mix" "--env.scss=1"

如果node_modules没有共享,那就可以了。如果它被共享它只是编译没有,因为它似乎无法真正找到合适的文件,因为node_modules指向一个符号链接。

知道在上面的场景中可以做些什么吗?

谢谢。

1 个答案:

答案 0 :(得分:0)

当您在linked_dirslinked_files中的文件中指定目录时,您正在指示Capistrano这些资源的权威版本/内容位于{{1} }} 目录。隐含地意味着不会使用git中相应的文件夹/文件。

对于链接目录,共享版本开始时完全为空。假设它是由构建过程填充的,或者由运行时的应用程序本身填充。

两个常见的例子说明了这一点:

  1. shared通常被链接为放置文件上传的位置。当用户将图像上传到应用程序时,它们将存储在共享位置,因此可供将来部署使用。
  2. public/systempublic/assets经常相关联,以存储tmp的输出和缓存。这可以加快未来部署中的预编译步骤。
  3. 重要的是,您永远不会将assets:precompliepublic/systemtmp签入git。 Capistrano没有机制将git中的内容与public/assets中的内容合并。 shared位置获胜。事实上,每次进行部署时,Capistrano 删除指定的文件/目录(如果它们存在于git中),然后用符号链接替换它们。

    总结:

    • sharedlinked_files告诉Capistrano:"忽略git中这些文件/目录的内容;使用我在linked_dirs代替"。
    • 提供的内容
    • 如果您在shared中指定了某些内容,则必须在部署之前在linked_files中创建它。否则,卡皮斯特拉诺没有任何东西可以链接到。
    • 对于shared,如果Capistrano无法找到要链接的指定目录,则会为方便起见创建一个空目录。
    • 在部署期间,Capistrano将已部署代码的符号链接创建为linked_dirs。如果部署的代码中已存在sharedlinked_files中的任何一个,则在添加符号链接之前将完全删除它们。
    • 永远不应将链接的文件/文件夹签入git。