2016-11-01 11 views
0

現時点ではプロダクションに配備しようとしているApostrophe-CMSのインスタンスがあります。実行してsudo npm start正常に動作し、アプリケーションが起動します。私はシンボリックリンクエラーを取得しています私が持ってしようとすると、しかし、PM2デーモンはそれを実行します。プロダクションでpm2のノードアプリケーションを起動する問題

Error: EEXIST: file already exists, symlink '/var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/public' -> '/var/sites/hackday-2016-microsite/public/modules/apostrophe-assets' hackday2016-28 at Error (native) hackday2016-28 at Object.fs.symlinkSync (fs.js:1048:18) hackday2016-28 at Object.self.linkAssetFolderOnUnix (/var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/index.js:447:10) hackday2016-28 at Object.self.linkAssetFolder (/var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/index.js:424:14) hackday2016-28 at /var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/index.js:402:14 hackday2016-28 at /var/sites/hackday-2016-microsite/node_modules/lodash/index.js:3073:15 hackday2016-28 at baseForOwn (/var/sites/hackday-2016-microsite/node_modules/lodash/index.js:2046:14) hackday2016-28 at /var/sites/hackday-2016-microsite/node_modules/lodash/index.js:3043:18 hackday2016-28 at Function.<anonymous> (/var/sites/hackday-2016-microsite/node_modules/lodash/index.js:3346:13) hackday2016-28 at self.symlinkModules (/var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/index.js:398:9) hackday2016-28 at /var/sites/hackday-2016-microsite/node_modules/async/lib/async.js:718:13 hackday2016-28 at iterate (/var/sites/hackday-2016-microsite/node_modules/async/lib/async.js:262:13) hackday2016-28 at async.forEachOfSeries.async.eachOfSeries (/var/sites/hackday-2016-microsite/node_modules/async/lib/async.js:281:9) hackday2016-28 at _parallel (/var/sites/hackday-2016-microsite/node_modules/async/lib/async.js:717:9) hackday2016-28 at Object.async.series (/var/sites/hackday-2016-microsite/node_modules/async/lib/async.js:739:9) hackday2016-28 at Object.self.afterInit (/var/sites/hackday-2016-microsite/node_modules/apostrophe/lib/modules/apostrophe-assets/index.js:349:20)

+0

うん、明確な質問ですか? pm2を使用して複数のインスタンスを同時に起動し、負荷分散していますか?それは悪くないですが、私が次に示唆するものには関連しています。 –

+0

PM2は、単一サーバー上の複数のノードアプリケーションを管理していますが、アポストロフィアプリケーションのインスタンスは1つだけ管理しています。 – jerikojones

+0

アポストロフィを実行しているユーザーに、パブリック/モジュールに適合すると見なす権限がない場合は、権限の問題になる可能性があります。 pm2はロードバランシングのために複数のプロセスを実行するように設定されていることもあります。デプロイ後とサーバー・プロセスを開始する前に、実行中の「ノード・アプリケーション・アポストロフィ:世代」を実行することをお勧めします。これにより、競合状態が回避されます。 –

答えて

0

私はあまりにもApostropheCMSにかなり新しいですし、いつかのために遊んでてきました。アポストロフィアセットフォルダをパブリックフォルダにリンクするためのシンボリックリンクが作成されているようですか?私はそれをする必要性を理解していません。 AposCMSは自動的

node_modules /アポストロフィ/ libに/モジュール/アポストロフィ-資産/公共と

の/ var /サイト/ hackday-2016-マイクロサイト/公共/モジュール/アポストロフィ資産フォルダ内のすべてのアセットをピックアップ。

あなたがしなければならないのは、あなたが /var/sites/hackday-2016-microsite/lib/modules/apostrophe-pages/index.jsの下でプロジェクトに追加している資産を宣言していることを確認している

ここ

私が持っているコードは、私のファイルの下

module.exports = { 
     park: [{ 
      slug: '/search', 
      type: 'apostrophe-search', 
      label: 'Search', 
      published: true 
     }], 
     types: [{ 
       name: 'default', 
       label: 'Default' 
      }, 
      { 
       name: 'home', 
       label: 'Home' 
      }, 
      { 
       name: 'apostrophe-blog-page', 
       label: 'Blog' 
      } 
     ], 

    //construct is one of the nunjucks functions that gets called when app.js starts 
    construct: function(self, options) { 

     //push assets to for use in front end - e.g. lib/modules/apostrophe-pages/public/js/site.js 

     self.pushAsset('script', 'site', { scene: 'always' }); 
     self.pushAsset('script', 'jquery.easing', { scene: 'always' }); 
     self.pushAsset('script', 'jquery.scrollTo', { scene: 'always' }); 
     self.pushAsset('script', 'bootstrap', { scene: 'always' }); 
     self.pushAsset('script', 'jquery.easing', { scene: 'always' }); 
     self.pushAsset('script', 'jquery.matchHeight', { scene: 'always' }); 
     self.pushAsset('script', 'jquery.easy-autocomplete', { scene: 'always' }); 
    } 
}; 

あるとCSSファイルを追加するために、あなたは

の/ var /サイト/ hackday-2016-マイクロサイト/公共/モジュールの下にあることを行うことができます/apostrophe-assets/public/css/site.less ファイルの私のコードは:

@import 'utilities/_index.less'; 
@import 'typography/_index.less'; 
@import 'layout/_index.less'; 
@import 'templates/_index.less'; 
@import 'components/_index.less'; 
@import 'global/_index.less'; 
@import 'components/easy-autocomplete.less'; 
@import 'components/easy-autocomplete.themes.less'; 
// this is the place were we are adding the css syles so that they get automatically compiled 
// and are minified and send out as one file 
@import 'custom/bootstrap.less'; 
@import 'custom/font-awesome.less'; 
@import 'custom/jquery.autocomplete.less'; 
@import 'custom/simple-sidebar.less'; 
@import 'custom/style.less'; 

.apos-slideshow-item 
{ 
    h4 
    { 
    display: none; 
    } 
} 
関連する問題