【问题标题】:There is no existing directory at ".../storage/logs" and it could not be created: Read-only file system“.../storage/logs”中没有现有目录,无法创建:只读文件系统
【发布时间】:2021-04-20 19:43:02
【问题描述】:

我的 API 中有上述错误。我正在使用 Laravel 版本 8,并将 API 部署在 Google Cloud App Engine 上。

我按照this tutorial的指示。 我正在尝试将生成的文件存储在 /tmp 文件夹中并将其上传到 Google Cloud Storage。 按照教程到Set up Stackdriver Logging and Error Reporting,但我得到了

There is no existing directory at ".../storage/logs" and it could not be created: Read-only file system

我对 DevOps 知识知之甚少,感谢您提供的任何帮助。

这是我的app.yaml 文件

runtime: php73

env_variables:
  ## Put production environment variables here.
  LOG_CHANNEL: stackdriver
  APP_KEY: my_app_key
  APP_STORAGE: /tmp
  VIEW_COMPILED_PATH: /tmp
  SESSION_DRIVER: cookie

在我的filesystems.php 文件中,我将符号链接设置为/tmp 文件夹

'links' => [
        public_path('storage') => storage_path('/tmp'),
],

这是我的 composer.json 文件

{
    "name": "laravel/laravel",
    "type": "project",
    "description": "The Laravel Framework.",
    "keywords": [
        "framework",
        "laravel"
    ],
    "license": "MIT",
    "require": {
        "php": "^7.3|^8.0",
        "ext-json": "*",
        "barryvdh/laravel-dompdf": "^0.9.0",
        "dompdf/dompdf": "^1.0",
        "fideloper/proxy": "^4.4",
        "fruitcake/laravel-cors": "^2.0",
        "google/cloud-error-reporting": "^0.18.3",
        "google/cloud-logging": "^1.21",
        "google/cloud-storage": "^1.23",
        "guzzlehttp/guzzle": "^7.0.1",
        "laravel/framework": "^8.12",
        "laravel/tinker": "^2.5"
    },
    "require-dev": {
        "facade/ignition": "^2.5",
        "fakerphp/faker": "^1.9.1",
        "laravel/sail": "^1.0.1",
        "mockery/mockery": "^1.4.2",
        "nunomaduro/collision": "^5.0",
        "phpunit/phpunit": "^9.3.3"
    },
    "config": {
        "optimize-autoloader": true,
        "preferred-install": "dist",
        "sort-packages": true
    },
    "extra": {
        "laravel": {
            "dont-discover": []
        }
    },
    "autoload": {
        "psr-4": {
            "App\\": "app/",
            "Database\\Factories\\": "database/factories/",
            "Database\\Seeders\\": "database/seeders/"
        }
    },
    "autoload-dev": {
        "psr-4": {
            "Tests\\": "tests/"
        }
    },
    "minimum-stability": "dev",
    "prefer-stable": true,
    "scripts": {
        "post-autoload-dump": [
            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
            "@php artisan package:discover --ansi"
        ],
        "post-root-package-install": [
            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
        ],
        "post-create-project-cmd": [
            "@php artisan key:generate --ansi"
        ],
        "post-install-cmd": [
            "composer dump-autoload",
            "@php artisan config:clear",
            "@php artisan config:cache"
        ]
    }
}

【问题讨论】:

  • 好像和这个question类似
  • 是的,@JohnMichaelGelilio 你是对的,但是,我在那里找不到解决方案。我已尝试更改 composer.json 文件中的权限。该教程引用了laravel version 5.4,我正在寻找使用更高版本部署它的人。我对云的了解很少。

标签: laravel google-app-engine logging google-cloud-platform laravel-8


【解决方案1】:

GAE 无法访问标准环境中的本地文件/存储,在这种情况下通常会给出 Read-only file system 错误。

由于您正在遵循适用于 GAE 标准的官方 Google 教程,请确认您的代码中的路径 $app->useStoragePath(env('APP_STORAGE', base_path() . '/storage'));(来自教程)实际上指向 google cloud env 上的路径,而不是您的本地文件结构。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-01-07
    • 1970-01-01
    • 2021-07-10
    • 2019-06-03
    • 1970-01-01
    • 2020-06-13
    • 2017-07-29
    • 2018-12-05
    相关资源
    最近更新 更多