我想了解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指向一个符号链接。
知道在上面的场景中可以做些什么吗?
谢谢。
答案 0 :(得分:0)
当您在linked_dirs
或linked_files
中的文件中指定目录时,您正在指示Capistrano这些资源的权威版本/内容位于{{1} }} 目录。隐含地意味着不会使用git中相应的文件夹/文件。
对于链接目录,共享版本开始时完全为空。假设它是由构建过程填充的,或者由运行时的应用程序本身填充。
两个常见的例子说明了这一点:
shared
通常被链接为放置文件上传的位置。当用户将图像上传到应用程序时,它们将存储在共享位置,因此可供将来部署使用。public/system
和public/assets
经常相关联,以存储tmp
的输出和缓存。这可以加快未来部署中的预编译步骤。重要的是,您永远不会将assets:precomplie
,public/system
或tmp
签入git。 Capistrano没有机制将git中的内容与public/assets
中的内容合并。 shared
位置获胜。事实上,每次进行部署时,Capistrano 删除指定的文件/目录(如果它们存在于git中),然后用符号链接替换它们。
总结:
shared
和linked_files
告诉Capistrano:"忽略git中这些文件/目录的内容;使用我在linked_dirs
代替"。shared
中指定了某些内容,则必须在部署之前在linked_files
中创建它。否则,卡皮斯特拉诺没有任何东西可以链接到。shared
,如果Capistrano无法找到要链接的指定目录,则会为方便起见创建一个空目录。linked_dirs
。如果部署的代码中已存在shared
和linked_files
中的任何一个,则在添加符号链接之前将完全删除它们。