Run occ:files scan as cronjob in container

So okay, this looks good and also match with the docs but this one here isn’t answered anywhere: Where can i set up the crontab itself? So you command is calling cron.php every 5 minutes and cron.php is doing his thing. Lets say i want to sync my files now every 5 minutes, before i added this in my crontab -e “sudo docker exec --user www-data nextcloud_app php occ files:scan --all” Where do i add know this “php occ files:scan --all” command after your command?

Your issue is perhaps that you are not pointing to where exactly occ is in your container.

You need to open up a terminal on your host machine. Then

sudo crontab -e

And at the end of that text file add your command:

*/5 * * * * docker exec -u www-data nextcloud php /var/www/html/occ files:scan -all

Ensuring that you are pointing to the correct location of occ in your container.

And this will need no cron docker container?

Or do i need a extra cron container an run the command like
*/1 * * * * docker exec -u www-data nextcloud_cron_container php /var/www/html/occ files:scan --all

Right now i stopped the cron container and just running my nc and db containers. I added this command */1 * * * * docker exec -u www-data nextcloud php /var/www/html/occ files:scan --all in my root crontab of my host system. I take a look in the web interface of nextcloud and see " Last job execution ran 12 minutes ago. Something seems wrong." So i guess it’s not running?

I get rid of this “something seems wrong” error if i deploy the cron container. So i guess i need the cron container AND ALSO a entry in my root crontab on my host?

I mean, it’s quite confusing as there are a lot of opinions and a lot of unanswered questions. Like, even if i create a cron container i need to add docker exec -u www-data nextcloud php -f /var/www/html/cron.php to my root cron on my host system in order to run it. But where can i add now my own crontabs? Like, i want to echo "helloworld" every minute INSIDE the nextcloud container. Where do i have to put the */1 * * * * echo "hellworld"? Inside the container? On my host? Inside the container into the cron.sh file? Somewhere else?

Please don’t not post unrelated questions into old topic but rather open new one and reference topics you find valuable. I’m going to split into separate conversation.

this command is not supposed to run on regular intervals. If you need to do so likely you are doing something strange with your system and should rethink you system usage.

My personal data are in some folders, just lets say its one folder. This one folder is a smb share because of reason. If i put a file into this folder from a system, no matter if its windows, macos or linux, it’s not visible in nextcloud web interface. It’s only visible after running php occ files:scan --all. So if i don’t use this command, i can’t see new files in nextcloud interface after moving/creating those in my smb share.

SMB share should be integrated using external_storage which allow regular files scan using internal mechanism. As long you have to run the command you better run it more precise only scanning the specific user/folder

1 Like

OK thanks, i will use the external storage app in future as i want to move all my data in the next months to another NAS.

But back to my main question: I created a cron container:

  cron:
    image: nextcloud:${NEXTCLOUD_VERSION}
    restart: always
    env_file:
      - db.env
      - smtp.env
    volumes:
      - nextcloud:/var/www/html
    entrypoint: /cron.sh
    depends_on:
      - app

After that, i create this entry in my root crontab:
*/5 * * * * docker exec -u www-data nextcloud_app_1 php -f /var/www/html/cron.php
which seems to trigger the cron.php file.

Now lets say i want to run my own cron. Whatever this is. This is why i choose this senseless */1 * * * * echo "hellworld" example - it can be everything. Where exactly do i setup */1 * * * * echo "hellworld? I looked around this forum here and googled but can’t find an answer. Everyone is saying “don’t use a container for this, just do docker exec [...] from host into the container to run a crontab whatever this is”, but this don’t seems to be the official solution. Thats why i am asking.

I don’t believe there is an “official” solution, as the Nextcloud Docker image is not officially supported and is a community maintained build.

If you want to run another cron inside the container (or any other container for that matter) for whatever other reason, you simply add your cron commands into your host crontab. Make sure you point to the correct container, as well as the correct location in the container.

It is also possible to set up a cron container, like you have, but I have found it to be superfluous, as my host crontab works just fine for my needs and maintaining another container just to run cron was a bit of an overkill. For others it might not be the case as they might be looking to do more complex things than just run a command at regular intervals.

Yeah and how do i create my own crontab for this cron container? Is it the same like creating a cronjob on my host system and point it to the cron container like

*/5 * * * * docker exec -u www-data nextcloud_cron php -f /var/www/html/cron.php
*/5 * * * * docker exec -u www-data nextcloud_cron php /var/www/html/occ whateveriwanttodo

# while the nextcloud instance itself is running in a container called nextcloud_app_1
1 Like

Write full path for php to avoid any confusion there.

The missing context is why do you need to run cron scan every 5 minutes? There is possibly a better solution.

1 Like

This is just an example. My main question is:

When i create cron container to run a crontab (no matter what it is, no matter how often i will run this), how can i still use exactly my own cronjobs.

Forget the cron containers. Useless complexity. System cron, or better yet, jus systemd periodic timers like this:

[~]$ cat .config/systemd/user/nextcloud-periodic-tasks.service
[Unit]
Description=Run nextcloud perdiodic jobs every 15-20 minutes

[Service]
Type=simple
ExecStart=/usr/bin/podman exec -u www-data nextcloud /usr/local/bin/php -f /var/www/html/cron.php


[~]$ cat .config/systemd/user/nextcloud-periodic-tasks.timer
[Unit]
Description=Run nextcloud perdiodic jobs every 15-16 minutes

[Timer]
OnBootSec=5min
OnUnitActiveSec=15min
RandomizedDelaySec=1min
AccuracySec=1

[Install]
WantedBy=default.target

So okay, this looks good and also match with the docs but this one here isn’t answered anywhere: Where can i set up the crontab itself? So you command is calling cron.php every 5 minutes and cron.php is doing his thing. Lets say i want to sync my files now every 5 minutes, before i added this in my crontab -e “sudo docker exec --user www-data nextcloud_app php occ files:scan --all” Where do i add know this “php occ files:scan --all” command after your command?

Sorry to revive this old topic but I think I need to make a few things clear to anyone in the future.

There is a lot of… I’m not sure what to call it… confusion I guess, around this. I’ll attempt to clear things up for future people.

The docs say to create a cron job. Great how?

Well there are basically two branches of Nextcloud users. The kind that have it running on bare metal or the ones running Nextcloud in Docker.

If you are running it bare metal create a cron job however you typically do that.
sudo crontab -e or sudo crontab -u web-data -e

The documentation I believe was written for people using Nextcloud on bare metal.

The solution if you are using Docker has basically two options:

  1. Create a cron job in the host system that calls a process in the docker container
    a) sudo crontab -e this will edit your cron jobs on the host and add,
    b) */5 * * * * docker exec -u www-data *conatiner_name* php /var/www/html/cron.php this will execute the docker command every 5 minutes. Container_name is the name of the container.

  2. Create a cron docker container inside of your nextcloud container as an example here is the snippet of my Compose file:

cron:
    image: nextcloud
    container_name: nextcloud-cron
    restart: always
    volumes:
      - ${PATH_TO_DATA}/nextcloud/html:/var/www/html
    environment: 
      - POSTGRES_HOST=postgresdb
      - POSTGRES_DB=${POSTGRES_DB}
      - POSTGRES_USER=${POSTGRES_USER}
      - POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
      - REDIS_HOST=redis
    entrypoint: /cron.sh
    depends_on:
      - postgresdb
      - redisdsadf

NOTE: This cron service is using Volume Sharing. It’s using the same volume as my nextcloud service inside my compose file. In order for this cron service to work properly it has to have exactly the same environment and configuration as the nextcloud service.

So those are the two options if you are using docker. Now from what I’ve seen / read what is happening is people are forgetting to match the same environment and then the cron job does not work.

Then they resort to option 1.

Note that option 2 is what they use at Docker Official Image

I’m using option 2.

Now to answer parents question. For anyone in the future as I’m sure it’s solved for him.

What you can do is what @R0Wi suggested using my example:

cron:
    image: nextcloud
    container_name: nextcloud-cron
    restart: always
    volumes:
      - ${PATH_TO_DATA}/nextcloud/html:/var/www/html
      - ${PATH_TO_DATA}/nextcloud/mycronfile:/var/spool/cron/crontabs/www-data
    environment: 
      - POSTGRES_HOST=postgresdb
      - POSTGRES_DB=${POSTGRES_DB}
      - POSTGRES_USER=${POSTGRES_USER}
      - POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
      - REDIS_HOST=redis
    entrypoint: /cron.sh
    depends_on:
      - postgresdb
      - redis

You can then put whatever information in mycronfile such as:

*/5 * * * * php -f /var/www/html/cron.php
0   0 * * 0 php -f /var/www/html/occ fulltextsearch:index

See his post here

I hope that will clear some things up for people. Bottom line the cron container needs to have the exact same access / information as the nextcloud container and you should be golden.

For references see:

I’m sure I read more at some point. If I made any mistakes feel free to correct me.

there is nothing more to say:

It’s best access files stored in Nextcloud through official interface e.g. WebDAV so the application can keep track of changes and offer functions like trashbin and versions. If you temper with Nextcloud’s storage the system might behave unexpected and data loss might occur. Nextcloud is designed to have exclusive access to the storage - everything else is wrong and you should stop doing so.

1 Like

@matt777 no idea why nobody is rly answering… i looked for the same solution to use my own cronjobs in nextcloud… i found the easiest way i guess…

i just used this container https://hub.docker.com/r/rcdailey/nextcloud-cronjob

i also added this variables to it
NEXTCLOUD_CONTAINER_NAME: Nextcloud (should be the name of your container)

NEXTCLOUD_CRON_MINUTE_INTERVAL: 5 (interval in minutes)

NEXTCLOUD_EXEC_USER: www-data (or whatever you use)
NEXTCLOUD_EXEC_SHELL: bash (or whatever you using)

Also adding 2 Mounts
/var/run/docker.sock:/var/run/docker.sock
/path/to/a/folder/on/host/scripts:/cron-scripts

In the second mounts folder create a script as example filescan.sh with this content

php -f occ files:scan --all

save it, start the container and it would be executed every 5 minutes… its also logging all executions like this

-------------------------------------------------------------
 Executing Cron Tasks: Sat Sep 14 00:00:00 UTC 2024
-------------------------------------------------------------
> Nextcloud Container ID: 4c105b8609f0
> Running Script: ./run-cron-php.sh
> Running Script: ./filescan.sh
Starting scan for user 1 out of 2 
Starting scan for user 2 out of 2 
+---------+-------+-----+---------+---------+--------+--------------+
| Folders | Files | New | Updated | Removed | Errors | Elapsed time |
+---------+-------+-----+---------+---------+--------+--------------+
| 17      | 88    | 0   | 0       | 0       | 0      | 00:00:03     |
+---------+-------+-----+---------+---------+--------+--------------+
> Done

No idea why here all discussing without a easy answer for your question but here it is. Hope it helps in future someone or it helps you if you never resolved it.