Upload all files to an object store

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • wtconseil
    Active Community Member
    • Apr 2015
    • 335

    Upload all files to an object store

    Hi

    i'm thinking about deploying EspoCRM on a docker container to have an immutable image.. and orchestrate my deployment through Kubernetes.

    EspoCRM will be running in HA mode, on many nodes, behind a load-balancer.

    I have currently a design issue regarding the upload folder.

    Is there a way (or is it in the roadmap) to have a connector to upload content to an "object-store" backend (ex: AWS S3 or Openstack Swift for example) rather than putting files in the local machine?

    Currently, because of this design, i have to sync between containers the upload folder.. (or bind-mount a volume..) between the host and the container..
    I think that it could be great to have this feature.

    SugarCRM (that was used before my POC) seems to have this uploadStream class:


    and we can configure the upload class wrapper in config file.

    That could be really awesome i guess to have that for Espo

    Thanks!

  • yuri
    Member
    • Mar 2014
    • 8542

    #2
    Hi,

    It was planned but no ETA available.
    If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

    Comment


    • huscmk
      huscmk commented
      Editing a comment
      Hi,

      Still no idea when it could be integrated ?

      Thanks
  • wtconseil
    Active Community Member
    • Apr 2015
    • 335

    #3
    Hi Yuri

    Let me know if you have some plan about that soon ?
    Thanks

    Comment

    • wtconseil
      Active Community Member
      • Apr 2015
      • 335

      #4
      I currently use a "technical solution" called Cloudfuse ( https://github.com/redbo/cloudfuse )
      it mounts a "swift container" (like a s3 bucket / cloud folder) and sync the file over http apicall

      But it don't think it could be interesting to continue with that over the time...

      Let me know if you have some plan to develop that "cloud folder" connector in a close futur?
      It's not possible for me any more to have data/upload folder directly on the filesystem any more :-(

      Comment

      • yuri
        Member
        • Mar 2014
        • 8542

        #5
        Yes. We have it on our roadmap. We will create a framework. But you will need to implement a wrapper class.
        Last edited by yuri; 02-08-2017, 01:33 PM.
        If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

        Comment

        • yuri
          Member
          • Mar 2014
          • 8542

          #6
          I think upload directory will be used anyway for storing files temporary when they are needed to be accessed by some existing implementations like Email Sending, Image transformation. It's easier for as because doesn't require us to rewrite a lot of code.
          Last edited by yuri; 02-08-2017, 03:37 PM.
          If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

          Comment

          • wtconseil
            Active Community Member
            • Apr 2015
            • 335

            #7
            Yes sure! But I have that this upload directory could act as a temp directory.
            If we lost it... it doesn't matter.

            All "expected" files will be in the object store.

            Comment

            • yuri
              Member
              • Mar 2014
              • 8542

              #8
              Here the commit: https://github.com/espocrm/espocrm/c...f61f06ff78d64d
              Not finished but the most important part is implemented
              If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

              Comment


              • huscmk
                huscmk commented
                Editing a comment
                Great news ! Will you tell us when it's finished ?

                Thanks !

              • yuri
                yuri commented
                Editing a comment
                In the next 4.5.0 release. Soon.
            • wtconseil
              Active Community Member
              • Apr 2015
              • 335

              #9
              Whoww ! great !

              how do you plan to help people to migrate to this kind of Storage Backend ?
              Meaning... I have a setup in production for more than 2 years now and many files.

              Should i migrate all the data/upload content manually to storage backend or could we have a small script to run that would use these controllers etc.. ?

              Thanks for your support and your good job !!

              Comment

              • yuri
                Member
                • Mar 2014
                • 8542

                #10
                If files will be stored in a single directory w/o subdirectories it will be easy to migrate. You will need to carry over all files from data/upload to your storage, run script in mysql that updates storage column of record in attachment table. And then you will need to write the implementation class for fetching, pushing, removing.

                But first, I need to finish all the work.
                If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

                Comment

                • jmreymond
                  Junior Member
                  • Feb 2017
                  • 5

                  #11
                  To be sure I have understand
                  Currently, we have very big documents like city maps, size is 300 MB for each map. It should be nice to store a document greater than 2 MB (for example) to an external storage provider like dropbox, Google drive, onedrive, ... as thunderbird filelink : https://support.mozilla.org/t5/Basic...nts/ta-p/16289
                  Will this be possible ?

                  Comment

                  • yuri
                    Member
                    • Mar 2014
                    • 8542

                    #12
                    We have planned this.
                    If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

                    Comment

                    • bandtank
                      Active Community Member
                      • Mar 2017
                      • 382

                      #13
                      Is there anything the community can do to help? I really want this feature and I am willing to contribute if there's a way to speed up the release. I want to start using EspoCRM, but storing files in a local upload folder is a deal breaker because the ephemeral nature of an EC2 instance is very risky.

                      Comment

                      • yuri
                        Member
                        • Mar 2014
                        • 8542

                        #14
                        In 4.5.0 release there will be a framework providing an ability to implement external storage. Release is planned for today.
                        If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

                        Comment

                        • wtconseil
                          Active Community Member
                          • Apr 2015
                          • 335

                          #15
                          Awesome :-))))
                          Thanks for your hard work!

                          Comment

                          Working...