Hatsu Posted November 27 Posted November 27 In Invision Community 5 there is a deprecation hint. Multiple file storage locations will be deprecated in a future release. It is recommended that you start consolidating files to a central location. Currently, I have all in uploads but my files from Downloads. This directory is outside webroot. What does this hint exactly mean? Only, that the multiple options Advertisements, Attachments, Badges etc. are moved to one directory or does it mean that the files from Downloads have to be moved as well? This is currently not in your deprecation tracker. SeNioR-, Patreon Lukazuki and G17 Media 3
Jim M Posted November 27 Posted November 27 Anything that isn't pointed to the uploads folder needs to get consolidated there. Hatsu 1
Hatsu Posted November 27 Author Posted November 27 (edited) Thank you. So I can't store my files from Downloads outside webroot anymore? Edited November 27 by Hatsu
Patreon Lukazuki Posted November 28 Posted November 28 also I have the same question, files in downloads are pointed to the storage similar to AWS S3 and use domain example storage.domain.com, also every uploaded image on the community is using private CDN in a domain: cdn.domain.com, how will it be possible to do when you deprecated multiple storage methods?
Marc Posted November 28 Posted November 28 I will not be. As mentioned in the message there, these must be consolidated into a single storage location
Patreon Lukazuki Posted November 28 Posted November 28 2 hours ago, Marc said: these must be consolidated into a single storage location I do not understand, What is the technical reason for deprecating such a useful feature? Why I should abandon optimization using CDN in favor of storing files in an uploads folder? many communities with downloads feature have a situation that makes it impossible to keep files in the uploads folder on the host because they have large files or too many files SeNioR- and G17 Media 2
Adriano Faria Posted November 28 Posted November 28 (edited) I never used an external storage and if it is really what it looks like (local storage only {uploads folder}), I’m curious: will this be discontinued for Cloud users too or only for self-hosted? I don’t see IPS hosting files from so many clients (+85%). That’s a genuine question. Edited November 28 by Adriano Faria Patreon Lukazuki, Hatsu and G17 Media 3
Joel R Posted November 28 Posted November 28 How will this be handled in the upgrade from 4 to 5? G17 Media and SeNioR- 2
Adriano Faria Posted November 28 Posted November 28 Just now, Joel R said: How will this be handled in the upgrade from 4 to 5? Not for 5.0.0. Future.
Randy Calvert Posted Thursday at 09:32 PM Posted Thursday at 09:32 PM An IPS staff person can correct me if I'm wrong, but my read of this was not that everything had to be ONLY under uploads, but that it had to be in a single location. Today, you could have a different storage location for each of the following: Advertisements, Attachments, Badges, Club Custom Fields, Clubs Images, Custom Emoji, Icons & Logos, Image Proxy Cache, Login Method Icons, Profile Photos, Custom Profile Fields, Social Media Promotion Images, Ranks, Reactions, Referral Banners, Theme Resources, Forum Cards, Forum Icons, Customer-Uploaded Advertisements, Support Request Custom Fields, Purchase Fields, Customer Fields, Payment Gateways, Product Groups, Product Images, CMS Media, CMS Pages, CMS Records, Calendar, Event Cover Photos, Gallery Images Do we really need a custom storage location for login method icons or custom profile fields, etc? It SOUNDS like they're saying you'll define a single location for storage (be it the "uploads" folder or an S3 bucket or whatever). Everything would be stored in that location, whatever/wherever it might be. So you could continue to use a CDN, however you would not be able to have multiple subdomains for each of them. It would simply be cdn.domain.com/club_images and cdn.domain.com/attachments or whatever the taxonomy is going to be. Adriano Faria 1
Adriano Faria Posted Thursday at 09:53 PM Posted Thursday at 09:53 PM (edited) 23 minutes ago, Randy Calvert said: An IPS staff person can correct me if I'm wrong, but my read of this was not that everything had to be ONLY under uploads, but that it had to be in a single location. Today, you could have a different storage location for each of the following: Advertisements, Attachments, Badges, Club Custom Fields, Clubs Images, Custom Emoji, Icons & Logos, Image Proxy Cache, Login Method Icons, Profile Photos, Custom Profile Fields, Social Media Promotion Images, Ranks, Reactions, Referral Banners, Theme Resources, Forum Cards, Forum Icons, Customer-Uploaded Advertisements, Support Request Custom Fields, Purchase Fields, Customer Fields, Payment Gateways, Product Groups, Product Images, CMS Media, CMS Pages, CMS Records, Calendar, Event Cover Photos, Gallery Images Do we really need a custom storage location for login method icons or custom profile fields, etc? It SOUNDS like they're saying you'll define a single location for storage (be it the "uploads" folder or an S3 bucket or whatever). Everything would be stored in that location, whatever/wherever it might be. So you could continue to use a CDN, however you would not be able to have multiple subdomains for each of them. It would simply be cdn.domain.com/club_images and cdn.domain.com/attachments or whatever the taxonomy is going to be. Interesting POV. Hope you’re right, even not having used it or needed it so far. Edited Thursday at 09:56 PM by Adriano Faria
KT Walrus Posted Thursday at 11:46 PM Posted Thursday at 11:46 PM I wish Invision would use the flysystem composer package in v5. I’ve been building apps in Laravel for the past six months and it is fantastic at letting you place your storage items anywhere you want using the league/flysystem package. There are so many great PHP composer packages these days, many of which can be used in any PHP, not just in the major frameworks like Laravel or Symfony. I plan on try to use Laravel’s Illuminate/Database package for Eloquent and Query Builder in my next Invision Community v5 app. This package uses PHP’s PDO driver so hopefully I can use SQLite and Postgres for per user SQLite databases and Postgres for my “source of truth” database.
sound Posted Friday at 10:14 AM Posted Friday at 10:14 AM (edited) 12 hours ago, Randy Calvert said: An IPS staff person can correct me if I'm wrong, but my read of this was not that everything had to be ONLY under uploads, but that it had to be in a single location. Today, you could have a different storage location for each of the following: Advertisements, Attachments, Badges, Club Custom Fields, Clubs Images, Custom Emoji, Icons & Logos, Image Proxy Cache, Login Method Icons, Profile Photos, Custom Profile Fields, Social Media Promotion Images, Ranks, Reactions, Referral Banners, Theme Resources, Forum Cards, Forum Icons, Customer-Uploaded Advertisements, Support Request Custom Fields, Purchase Fields, Customer Fields, Payment Gateways, Product Groups, Product Images, CMS Media, CMS Pages, CMS Records, Calendar, Event Cover Photos, Gallery Images Do we really need a custom storage location for login method icons or custom profile fields, etc? It SOUNDS like they're saying you'll define a single location for storage (be it the "uploads" folder or an S3 bucket or whatever). Everything would be stored in that location, whatever/wherever it might be. So you could continue to use a CDN, however you would not be able to have multiple subdomains for each of them. It would simply be cdn.domain.com/club_images and cdn.domain.com/attachments or whatever the taxonomy is going to be. storing your theme/css/javascript files in the same single storage location as say your gallery images (s3 bucket) may not work that well in some cases On 11/27/2024 at 6:51 PM, Jim M said: Anything that isn't pointed to the uploads folder needs to get consolidated there. is there a time scale yet for this depreciation? Edited Friday at 10:14 AM by sound
Esther E. Posted Friday at 12:11 PM Posted Friday at 12:11 PM 14 hours ago, Randy Calvert said: An IPS staff person can correct me if I'm wrong, but my read of this was not that everything had to be ONLY under uploads, but that it had to be in a single location. Today, you could have a different storage location for each of the following: Advertisements, Attachments, Badges, Club Custom Fields, Clubs Images, Custom Emoji, Icons & Logos, Image Proxy Cache, Login Method Icons, Profile Photos, Custom Profile Fields, Social Media Promotion Images, Ranks, Reactions, Referral Banners, Theme Resources, Forum Cards, Forum Icons, Customer-Uploaded Advertisements, Support Request Custom Fields, Purchase Fields, Customer Fields, Payment Gateways, Product Groups, Product Images, CMS Media, CMS Pages, CMS Records, Calendar, Event Cover Photos, Gallery Images Do we really need a custom storage location for login method icons or custom profile fields, etc? It SOUNDS like they're saying you'll define a single location for storage (be it the "uploads" folder or an S3 bucket or whatever). Everything would be stored in that location, whatever/wherever it might be. So you could continue to use a CDN, however you would not be able to have multiple subdomains for each of them. It would simply be cdn.domain.com/club_images and cdn.domain.com/attachments or whatever the taxonomy is going to be. This is correct. 1 hour ago, sound said: storing your theme/css/javascript files in the same single storage location as say your gallery images (s3 bucket) may not work that well in some cases Why not?
KT Walrus Posted Friday at 12:59 PM Posted Friday at 12:59 PM (edited) 49 minutes ago, Esther E. said: Why not? Last time I tried to store everything in an S3 bucket, it slowed the site down incredibly since uploading to S3 was incredibly slow. Downloading is fine though in most cases. How slow will it be to upload all those theme/css/javascript files? Is this only an issue IN_DEV or will it affect prod? Or, is most of the uploading done in a cronjob? Maybe I don’t understand how these non-user uploaded files are handled by the framework I suppose Invision has thoroughly tested the performance aspects of storing everything in an S3 bucket before making the huge decision to deprecate multiple storage methods so I should trust that this isn’t going to slow down my site from a user’s perspective. I’m worried that this is a bad decision. I wish Invision would support Flysystem for flexibly storing anything anywhere on a collection basis. Flysystem is fantastic in Laravel. Edited Friday at 01:02 PM by KT Walrus SeNioR-, Patreon Lukazuki and G17 Media 2 1
Jim M Posted Friday at 01:20 PM Posted Friday at 01:20 PM 14 minutes ago, KT Walrus said: Last time I tried to store everything in an S3 bucket, it slowed the site down incredibly since uploading to S3 was incredibly slow. Downloading is fine though in most cases. How slow will it be to upload all those theme/css/javascript files? Our Cloud stores everything in S3 and so do countless self-hosted users. You also are not forced to stored everything in S3 if you don't want too though.
Dll Posted Friday at 01:43 PM Posted Friday at 01:43 PM 42 minutes ago, KT Walrus said: Last time I tried to store everything in an S3 bucket, it slowed the site down incredibly since uploading to S3 was incredibly slow. I can't say that's ever been our experience. Maybe you were using a location a long way from your server? It's always best to choose the nearest one possible.
sound Posted Friday at 01:58 PM Posted Friday at 01:58 PM 29 minutes ago, KT Walrus said: Last time I tried to store everything in an S3 bucket, it slowed the site down incredibly since uploading to S3 was incredibly slow. Downloading is fine though in most cases. How slow will it be to upload all those theme/css/javascript files? Is this only an issue IN_DEV or will it affect prod? Or, is most of the uploading done in a cronjob? Maybe I don’t understand how these non-user uploaded files are handled by the framework I suppose Invision has thoroughly tested the performance aspects of storing everything in an S3 bucket before making the huge decision to deprecate multiple storage methods so I should trust that this isn’t going to slow down my site from a user’s perspective. I’m worried that this is a bad decision. I wish Invision would support Flysystem for flexibly storing anything anywhere on a collection basis. Flysystem is fantastic in Laravel. 1 hour ago, Esther E. said: Why not? I'd say cost and performance, as was talking self hosted sites there if we move to one single location then using a separate s3 bucket set up for large file directories such as gallery etc isn't possible while such a move isn't end of the world stuff, I just thought that it needed mentioning as it is removing options off topic but while here, I did send a pm ref support issue on your old account a few days ago Quote is there a time scale yet for this depreciation? guess we are talking months here, yep?
KT Walrus Posted Friday at 02:10 PM Posted Friday at 02:10 PM 42 minutes ago, Jim M said: Our Cloud stores everything in S3 and so do countless self-hosted users. You also are not forced to stored everything in S3 if you don't want too though. Don’t you use only AWS? That would explain why you don’t see a performance penalty for uploading to S3. I won’t use AWS or any big cloud service. I stay away due to cost and vendor lock in. I use Backblaze B2 for user uploaded content and local Minio S3 for everything else (and temporarily storing some user content).
Jim M Posted Friday at 02:35 PM Posted Friday at 02:35 PM 20 minutes ago, KT Walrus said: I use Backblaze B2 for user uploaded content and local Minio S3 for everything else (and temporarily storing some user content). If you're seeing performance impacts, you should explore your hosting and your connection to the vendors. The performance impact should be negligible. We run tests outside of our own AWS environment and we also are exploring other vendors where the cache reset on the theme files in v4 aren't an issue. Keep in mind, with v5, this won't be an issue because there are theme changes between v4 and v5 that rebuilds won't happen so frequently.
Randy Calvert Posted Friday at 03:23 PM Posted Friday at 03:23 PM 5 hours ago, sound said: storing your theme/css/javascript files in the same single storage location as say your gallery images (s3 bucket) may not work that well in some cases It’s the default behavior for any vanilla self hosted install and literally all cloud install. Jim M 1
sound Posted Saturday at 09:23 AM Posted Saturday at 09:23 AM 17 hours ago, Randy Calvert said: It’s the default behavior for any vanilla self hosted install and literally all cloud install. you read it wrong, I was pointing out that splitting storage locations via 2 different servers (self/S3) will no longer be possible no big deal, just another option removed onwards...
Randy Calvert Posted Saturday at 11:46 PM Posted Saturday at 11:46 PM On 11/29/2024 at 9:10 AM, KT Walrus said: Don’t you use only AWS? That would explain why you don’t see a performance penalty for uploading to S3. I won’t use AWS or any big cloud service. I stay away due to cost and vendor lock in. I use Backblaze B2 for user uploaded content and local Minio S3 for everything else (and temporarily storing some user content). It looks like IPS is using Backblaze as well... I just looked at my cloud install and all of the storage is now on a non-S3 bucket.
Recommended Posts