skillup

技術ブログ

サーバー・ネットワーク

herokuでのhttpd.conf設定

投稿日:

前回の記事でLet’s EncryptでSSL設定する場合、 http://ドメイン/.well-known/ というURLにアクセスする必要があります。

ただherokuの場合、隠しフォルダ、隠しファイル自体が403エラーになり、アクセス自体ができないんですよね。

アプリ側でルーティングを設定しようが、htaccessでコントロールしようができませんでした。

herokuの場合、サーバーの設定などはすでに出来上がっており、カスタマイズが難しいんですよね。

四苦八苦して調べたところ、httpd.conf自体を上書きできるとのことでなんとか上記URLにアクセスさせることができました。

Procfile

herokuのようなPaasの場合、何も設定をしなくてもある程度動かすことができますが(正確にいうと省略されてる)、細かいカスタマイズやコマンドなどを入れることもできます。

その場合、ルートディレクトリにProcfileというテキストを作り、ここに起動コマンドを書いておくことで任意の設定ファイル(httpd.confなど)を読み込ませることができます。

Herokuに必要なProcfileの書き方についてまとめておく

Procfileですが、今回私が書いたのは下記の一行だけです。

herokuの管理画面を見ると
web heroku-php-apache2 となっていますが、これがherokuが動いているプラットフォーム(dynoと言います。)になります。

実際にはここが起動しているようですので、起動コマンドが web: vendor/bin/heroku-php-apache2 のようになります。

修正したhttpd.confですが以下がheroku上で使われている実際はgitで確認できます。
https://github.com/heroku/heroku-buildpack-php/blob/master/conf/apache2/heroku.conf

私の場合、上記ファイルをまずそのままコピペし、Procfileと同階層(つまりはルートディレクトリ)におき、

のように書き換えてアップしたところ無事隠しフォルダが見えました。(結果としてこれ自体は前回の記事で触れた通り、使用しなかったのですが・・・)

他にも色々と設定変更ができるようです。

-サーバー・ネットワーク
-

執筆者:


  1. […] (注:実はherokuの場合このurl自体にアクセスをさせるのが大変でした・・・ 参考リンク herokuでのhttpd.conf設定 ) […]

comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

no image

inotifyによる検知

以前、pynotifyというpythonの検知プログラムを書きましたが、元々はinotifyというLinux上のパッケージのライブラリが元になっています。 以前調べたリンク 監視検知処理に関して 実務 …

no image

sourceコマンドに関して(Linuxサーバー&MySQL)

Linux上ではコマンドをテキストファイルに記述して、

と入力すると命令を実行してくれます。 シェルスクリプトよりもお手軽に実行できる …

no image

crontab 確認方法

crontabが動かないときに確認すること。 Contents1 cron自体が動いているか(下記コマンドでログを確認)2 実行権限が正しいか3 プログラム内部のファイルパスが絶対パスになっているか4 …

no image

Vagrantでのフォルダ共有

Contents1 vagrantとホストOSのフォルダの共有2 ネットワークアダプタ設定3 任意のディレクトリをマウント vagrantとホストOSのフォルダの共有 ディフォルトではvagrantは …

no image

命名に関して

現在、大規模なインフラ関連の開発をしており、インフラに関してはIaCで管理をしております。 ただ、リソースが数十〜数百もあるため、命名を適切していないとカオスになりますね・・・ 現在の案件で命名に関し …

アーカイブ