3

我正在使用Capistrano將我的Rails應用程序部署到VPS(如episode 335 on railscasts.com所示)。我有一些用於應用程序的自定義字體,並且不希望將其用於源代碼控制以獲得許可原因(請參見底部的說明)。如何部署無法使用Capistrano進行版本控制的授權字體?

這是什麼最好的方法呢?我應該編輯deploy.rb文件以從本地計算機上訪問assets/webfonts目錄嗎?也許我只需要將它們手動複製到VPS上的my_app/shared/assets目錄中,但我寧願將它作爲部署任務的一部分進行自動化。

這是我目前的deploy.rb文件:

require "rvm/capistrano" 
require "bundler/capistrano" 

server "ip_address", :web, :app, :db, primary: true 

set :application, "armory" 
set :user, "username" 
set :deploy_to, "/home/#{user}/apps/#{application}" 
set :deploy_via, :remote_cache 
set :use_sudo, false 

set :scm, "git" 
set :github_user, "gorrillamcd" 
set :repository, "[email protected]:#{github_user}/Armory.git" 
set :branch, "master" 

default_run_options[:pty] = true 
ssh_options[:forward_agent] = true 

after "deploy", "deploy:cleanup" # keep only the last 5 releases 

namespace :deploy do 
    %w[start stop restart].each do |command| 
    desc "#{command} unicorn server" 
    task command, roles: :app, except: {no_release: true} do 
     run "/etc/init.d/unicorn_#{application} #{command}" 
    end 
    end 

    task :setup_config, roles: :app do 
    sudo "ln -nfs #{current_path}/config/nginx.conf /etc/nginx/sites-enabled/#{application}" 
    sudo "ln -nfs #{current_path}/config/unicorn_init.sh /etc/init.d/unicorn_#{application}" 
    run "mkdir -p #{shared_path}/config" 
    put File.read("config/database.base.yml"), "#{shared_path}/config/database.yml" 
    puts "Now edit the config files in #{shared_path}." 
    end 
    after "deploy:setup", "deploy:setup_config" 

    task :symlink_config, roles: :app do 
    run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml" 
    run "ln -nfs #{shared_path}/config/initializers/stripe.rb #{release_path}/config/initializers/stripe.rb" 
    end 
    after "deploy:finalize_update", "deploy:symlink_config" 

    desc "Make sure local git is in sync with remote." 
    task :check_revision, roles: :web do 
    unless `git rev-parse HEAD` == `git rev-parse origin/master` 
     puts "WARNING: HEAD is not the same as origin/master" 
     puts "Run `git push` to sync changes." 
     exit 
    end 
    end 
    before "deploy", "deploy:check_revision" 
end 

編輯:對不起,如此模糊的事前。我使用myfonts.com的Museo Slab和github上的公共回購(如果您想查看,請查看我的用戶配置文件)。我通過許可證閱讀並發現這一點:

3.授權許可的web字體(S)可以對被許可方所擁有或控制的任何網站使用

4.機構負責多個客戶的網站,例如網頁設計機構或託管服務提供商可能不會在多個客戶的網站上共享單個Webfont許可。

許可的這兩行讓我相信,檢查字體到一個公共倉庫將是對許可,因爲它可以在不屬於我的網站未取得新許可證的字體使用(甚至儘管他們可以自由開始)。我想其他人以前有過這個問題。所以我的問題是,使用Capistrano字體(或任何其他文件)處理部署的正常/最佳方式是無法檢入源代碼管理的?

+1

您可以通過網絡向任何人提供服務,但不允許將他們檢入源代碼管理?如果沒有關於你能做什麼和不能做什麼的更多信息,我很難提出建議。 – willglynn

+1

我同意willglynn ..授權理由不應該真的阻止你檢查他們到源代碼管理.. webfonts通常是有限的在他們的使用領域,但不是在他們的二進制分佈..我建議你只是檢查他們到你的sourcecontrol .. – Tigraine

+1

對不起,我應該更具體。我從myfonts.com使用Museo Slab,我有一個公共存儲庫。我的印象是,這可能屬於「分發」,因爲有人可以分叉存儲庫並以這種方式獲取字體,但是如果我錯了,有人可以糾正我。它肯定會讓它們更容易放入回購。 – GorrillaMcD

回答

3

我會將Web字體打包到一個存檔中,並將該存檔放在與存儲庫分開的某處。 (Amazon S3是主要的候選人。)然後,我會在發佈時檢索並解壓縮該歸檔文件。

這可讓您將整個應用程序放入公共存儲庫 - Capistrano腳本,Rake任務等 - 但將實際的字體二進制文件留下,並將其位置指定爲配置。這與12-factor app principles一致,將這些Web字體視爲您的應用程序所需但未包含的外部資源。

例如,您可以指定一個WEBFONTS_URL環境變量,並添加一個fetch_webfonts Rake任務。此任務會自動將這些資源拉入您的應用程序,並且在未指定WEBFONTS_URL的情況下不會執行任何操作 - 例如,如果其他人在沒有這些字體的情況下檢查了您的回購協議。 (你甚至可以讓這個任務用樣式表做適當的事情,確保新簽出的用戶在字體文件中沒有404的情況下獲得一個可用的應用程序。)Rake允許你添加依賴到現有的任務,所以你可以確保這是自動的Capistrano很可能已經調用了assets:precompile

此外,此方法在開發和生產中同樣適用:您可以重新檢出自己的回購,指定適當的WEBFONTS_URL,並在本地計算機上最終生成一組可用的字體。 (使用dotenv gem可以很容易地將開發配置集成到環境變量中,保持您的所有環境一致。)請確保您的結果不會因爲意外而公開發布。

1

您可以使用rsync上傳/同步字體目錄。例如:

添加您的IP /域名轉讓給獨立的變量:

set :host, "ip_address" 
server host, :web, :app, :db, primary: true 

,並添加一個任務運行

`rsync -vz app/assets/webfonts #{user}@#{host}:#{shared_path}/assets/webfonts` 

然後用符號鏈接到應用程序的當前版本喜歡做已經在部署腳本中使用database.yml和stripe.rb

+0

在這裏,rsync會覺得駭人聽聞,因爲考慮到Capistrano已經有一個開放的SSH連接到正確的主機並具有正確的憑據,知道所有的路徑,等等。 – willglynn

+0

謝謝你的回答。我同意@willglynn,我知道capistrano可以使用scp或sftp進行文件傳輸,但是,如果rsync比其他方法有一些優勢,請告訴我。 – GorrillaMcD

相關問題