-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Trashbin auto-expire causes PHP timeout on delete #13974
Comments
Some of the queries running on the mysql database:
Which it seems to have all the heavy load on the server side. |
We improved delete operation with oc8. Please retest these says after release. |
OC 8 is out, please retest 😄 The problem is that files were copied to trashbin instead of moving. Now in OC 8 they are moved, so should be much faster. |
Exactly the same result with oc8 Here is the full server log of sync:
Nevertheless the file file which caused the timeout appears as deleted on the deleted files directory. |
I only see a single "DELETE" operation. Are you saying that this one failed too ? If in your case it happens also for single files, then it's another bug. 😦 |
All the DELETE operations fail with a timeout on the php backend (php-fpm), so nginx returns the 504 error. php-fpm is configured to kill the process after 10 minutes of running. What I'm saying is that there is something wrong because it lasts 10 minutes to delete a file. In the other hand, the file which causes the timeout appears correctly on deleted files, but the requests didn't end correctly as it produced the timeout. So it seems that all the work is done correctly, but the requests never ends. I did delete a lot of files on a previous version (i think it was 6.0) without any problems and the process was quite fast. Let me know if you need any more info. If you give point to the source code on the delete part i may debug it further to provide more information. |
I see encryption is disabled (which would have slowed down deletion due to share keys handling), so that is ruled out. Was that file shared with many users ? |
Random shot in the dark: did you at some point have symlinks in your "data" directory ? (because those could cause infinite loops) |
The file is not shared. And i checked and no i don't have symlinks.
/owncloud is my data path |
Hmm... still clueless. And then next try: disable the app "Deleted files" then delete a file. To rule out whether it's related to the trashbin app or something else. |
Log with trashbing:
Worked well with trashbin disabled, so it's something related to trashbin. |
Is your trashbin very full ? Another theory for the slowness is that the trashbin tries to expire old files automatically. If there are many such files, it might be slow. If you have lots of files, you could try and manually empty the trashbin, then try deleting a file again. CC @schiesbn |
Do you think this is very full?
I just selected all files in trashbin and deleted them, i will keep you update when the process ends, but i think it will last some time. There is some method to empty the trashbin instead of selecting all and delete them? I was thinking on creating some app to expire files on trashbin after xxx days. Do you think this is interesting for core? |
There is already a request for a CLI tool to auto-clear the trashbin but I can't seem to find it |
So the timeout disapears when the trashbin is empty, so its related to the size of the trashbin. Maybe the issue it's #8109 |
Ok thanks for the info. |
@schiesbn how about auto-expiring as a background job ? |
the way to go from my understanding - moving the trashbin's expiry hook into a background job should not be that complicated |
@icewind1991 we did talk about this today - let us know about your progress - THX |
Looking into added laravel's background queue system to handle this atm |
Try to increase |
trashbin expiry will be done in a background process starting 8.1 - see #14644 |
There are three tasks to address trashbin slowness:
|
should be fixed for 8.1 |
"Make trashbin expiration faster for OC < 8.1" (backport) still needs to be reviewed: #14926 |
I'm using the owncloud app to sync my local files with remote storage.
Steps to reproduce
Expected behaviour
The files should be deleted on the owncloud server without errors.
Actual behaviour
The owncloud server raises timeout errors when deleting the files. I had a timeout of 5 minutes, and modified php-fpm configuration to timeout on 10 and the problem still persits. I belive that 10 minutes to delete a single file is too much and something is wrong.
I can see some deleted files in the deleted files view in the web interface. For example is see that file Imatges/Whatsapp/IMG-20121002-WA0001.jpg is deleted, but as you can see in the log it raises a timeout on the client.
Server configuration
Operating system: Debian 7.8
Web server: Nginx + PHP-FPM
Database: MariaDB 5.5.35
PHP version: PHP 5.4.36
ownCloud version: ownCloud 7.0.4 (stable)
Updated from an older ownCloud or fresh install: Upgraded from an older version
List of activated apps: Activity, Calendar, Contacts, Deleted Files, Documents, First Run Wizard, PDF Viewer, Pictures, Share Files, Text Editor, Updated, Versions, Video Viewer.
The content of config/config.php:
Are you using external storage, if yes which one: No external storage
Are you using encryption: no
Client configuration
Browser: Firefox 35.0.1
Operating system: Linux Mint Rebeca (Ubuntu 14.04)
Mirall version: 1.7.1
Logs
Web server error log
There a lot of entries like this.
And in mirall i see the following output:
ownCloud log (data/owncloud.log)
Nothing relevant on owncloud.log only errors related to mysql restart i have done manually.
Let me know if anything else is required to properly fix the bug.
The text was updated successfully, but these errors were encountered: