Changes for page SMB Connectivity
                  Last modified by Danniar Firdausy on 2024/09/18 20:40
              
      
      From version  19.1 
    
    
              edited by Bouke Reitsma
        
on 2024/05/13 13:01
     on 2024/05/13 13:01
      Change comment:
              There is no comment for this version
          
         
      To version  4.2 
    
    
              edited by Bouke Reitsma
        
on 2024/05/02 10:58
     on 2024/05/02 10:58
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -14,106 +14,123 @@ 14 14 15 15 By SMB connectivity, we mean: Making sure that eMagiz can communicate with the SMB protocol to exchange file-based data. 16 16 17 -* SMB(ServerMessage Block) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections.18 -* In an SMBtransaction, the end user's computer is typically called the localhost. The second computer involved inSMBis a remote host, which is usually a server.19 -* Servers must be set up to run SMBservices, and the client must haveSMBsoftware installed to access these services.20 -* eMagiz provides several components to set up the SMBconnection17 +* FTP (File Transfer Protocol) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections. 18 +* In an FTP transaction, the end user's computer is typically called the localhost. The second computer involved in FTP is a remote host, which is usually a server. 19 +* Servers must be set up to run FTP services, and the client must have FTP software installed to access these services. 20 +* eMagiz provides several components to set up the FTP connection 21 21 22 -== 3. SMBConnectivity ==22 +== 3. FTP Connectivity == 23 23 24 -In some cases, there is no communication possible with a local file directory. Or there is a requirement from the external party to place the files somewhere else. Mainly the somewhere else is either an FTP or an SFTP. However, thereisa third communication protocolthat can beused for file transfer. Inthis microlearning we willtake alook atServerMessageBlock(SMB)connectivitywithin eMagiz.24 +In some cases, there is no communication possible with a local file directory. Or there is a requirement from the external party to place the files somewhere else. Mainly the somewhere else is either an FTP or an SFTP. This microlearning will look at the FTP and learn how to set up the connection between eMagiz and the FTP. 25 25 26 -* SMB(ServerMessage Block) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections.27 -* In an SMBtransaction, the end user's computer is typically called the localhost. The second computer involved inSMBis a remote host, which is usually a server.28 -* Servers must be set up to run SMBservices, and the client must haveSMBsoftware installed to access these services.29 -* eMagiz provides several components to set up the SMBconnection26 +* FTP (File Transfer Protocol) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections. 27 +* In an FTP transaction, the end user's computer is typically called the localhost. The second computer involved in FTP is a remote host, which is usually a server. 28 +* Servers must be set up to run FTP services, and the client must have FTP software installed to access these services. 29 +* eMagiz provides several components to set up the FTP connection 30 30 31 -So, where the file pickup component searches on the local host for the correct directory, the idea of the SMBsetup is that the directory with whom to communicate exists on a remote host. The local host and the remote host can talk to each other via theSMBprotocol. That is, in a nutshell, the difference between setting up anSMBconnection and communicating with local directories.31 +So, where the file pickup component searches on the local host for the correct directory, the idea of the FTP setup is that the directory with whom to communicate exists on a remote host. The local host and the remote host can talk to each other via the FTP protocol. That is, in a nutshell, the difference between setting up an FTP connection and communicating with local directories. 32 32 33 -eMagiz provides o nlyonesupport objects to connect to anSMB:33 +eMagiz provides two support objects to connect to an FTP: 34 34 35 -* SMB session factory 35 +* Default FTP caching session factory 36 +* Default FTP session factory 36 36 37 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity- smb-connectivity-smb-support-object.png]]38 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-support-objects.png]] 38 38 39 - ===3.1Configuration in eMagiz===40 +The main difference between the two is the caching part. The caching session factory comes with the option to re-use the existing session for multiple requests. In other words, this way, you do not have to authenticate yourself every time you want to communicate with the FTP. This behavior is beneficial if a high frequency of communication is needed between eMagiz and the FTP to handle the incoming and outgoing data packages. 40 40 41 - Toconfigurethe connectionbetween eMagiz and theSMB, weeedtwo(orthree)components.This dependson whetherwewanttoread, writeordoboth whileunicatingwith theSMB. If we'regoing todoboth, weneed bothofhefunctional components.In all otherscenarios,you onlyneedone ofthefunctionalcomponents. The functionalcomponents thatyou might need arecalled:42 +If you only initiate communication infrequently, for example, once per day, the default session factory becomes more interesting as this closes the session after each transmission. This behavior is beneficial in cases of low-frequency communication because otherwise, the session would remain active for an extensive period. 42 42 43 -* SMB inbound Channel adapter 44 -* SMB outbound Channel adapter 44 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-caching-help-text.png]] 45 45 46 - Ontopofthat, you needthefollowingsupportobjects.46 +=== 3.1 Best practices for using FTP === 47 47 48 - *SMBsession factory48 +==== 3.1.1 Which session factory do I need? ==== 49 49 50 - Inthismicrolearning,wewilluse theSMBinbound channeladaptercombined withtheSMBsession factorytoillustratetheconfiguration.Please note thatanyother combinationworkssimilarly.To configuretheconnectionwiththeSMB, wefirstnavigateto the Create phaseofeMagiz. Here weopentheflowwewanttoedit.In thisexample,thatwillbeanentryflowas wewant to retrieve(read) datafrom the SMB.50 +When occasionally retrieving or writing files to FTP, use the _Default FTP session factory_. A new connection will be set up when you use the _Default FTP session factory_ for every message/file. On some FTP servers, this might take up to seconds for each login. This fact might impact the performance of your flow. 51 51 52 -When you have opened the flow,youneedtoenter"StartEditing"mode.Afterouhave done so,we first addtheSMBsession factory supportobjectto our flow.52 +When you need better performance (say writing multiple files in a minute or retrieving files every minute), use the _Default FTP **caching** session factory_. The _Default FTP **caching** session factory_ shares FTP sessions for messages in your flow. 53 53 54 - [[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-session-factory-empty.png]]54 +==== 3.1.2 Do I have to set up a retry mechanism? ==== 55 55 56 - Here,we need to define thefollowing:56 +When writing files to FTP, it is advisable to set a retry mechanism. Find the advanced tab on your _FTP outbound channel adapter_. Under _Request handler advice chain_ add a _Retry Advice_. 57 57 58 -* Host 59 -* Port 60 -* Username 61 -* Password 62 -* Share and directory 58 +==== 3.1.3 I get a _Failed to list files/items_ or a _Failed to obtain pooled item_. What can I do? ==== 63 63 64 -{{info}} 65 -The value for the share and directory field is the main folder for your file share. If the main folder is the exchange folder, this should be referenced with a /. 66 -{{/info}} 60 +Incorrect connection settings can cause this. Check whether the correct properties have been set and whether the runtime has retrieved the latest properties. 67 67 68 - [[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-session-factory-filled-in.png]]62 +==== 3.1.4 I get a _Failed to list files / items_, a _Pipe closed_ or an _input stream is closed_. What can I do? ==== 69 69 70 - The settingsthe Advanced tab don'thave to be changedinmosts.If yourspecific setupdoesrequireachangeto theseettings,pleaseconsult thehelptextsonhecomponentlevel foradvice.64 +A closed FTP session can cause these notifications due to inactivity. For the _Default FTP **caching** session factory_, always set the _Server alive interval_ property to 30000 (ms). 71 71 72 - Nowthatwehaveconfigured the supportobject addingtheSMB inboundchanneladaptertothe flow has become time.66 +==== 3.1.6 I get a _Failed to write to_. What can I do? ==== 73 73 74 - [[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-inbound-channel-adapter-empty.png]]68 +Maybe the target folder does not exist, and the _Auto-create directory_ is off. It is also possible that the connection settings are incorrect. Check whether the correct properties have been set and whether the runtime has retrieved the latest properties. 75 75 76 - Inthiscomponent,we need todefinetheremotedirectory wherethe originalfiles are located.We need tospecifythelocaldirectoryused tostorethefilesbeforetheyareprocessed temporarily. Furthermore, we needtolinkthesupportbjectwehave just created anddefinea poller. For that lastone,thebestpracticeistheuseofacrontrigger.70 +==== 3.1.7 I often get 'Disconnecting from sftp.example.com port 22' and then a 'Caught an exception, leaving main loop due to Socket closed' warnings. ==== 77 77 78 - [[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-inbound-channel-adapter-filled-in.png]]72 +Too many connections can cause this to the same server at the same time. If you have many flows connecting to the same FTP server, ensure that the crons do not trigger simultaneously. 79 79 80 - Apart from these configurations, you could also add a filter, just as we learned in the [[Crash Course Messaging on file-based connectivity>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.WebHome||target="blank"]].Finishing things off, we should consider the delete behavior we will use.Based on the filter and the business requirements, whether to delete and when to delete could differ.So please consider all your options in that regard.Incase there are multiple readers from the folder and/or there are legal requirementsto store source files foracertain time period, you should not usethedeleteremote filesoption.However, not deleting files read filescan cause overloading themachine if no alternativedelete policies is inplace.74 +==== 3.1.8 I get a 'Failed to create SFTPClient' ==== 81 81 82 - ===3.2SMBGateway===76 +SFTP, FTP, and FTPS are three different remote file transfer protocols with their _session factory_ components in the eMagiz flow designer. Make sure you use the one that corresponds to the server's protocol. 83 83 84 - TheSMBGatewayis an additionalcomponentthat can beused tointeractwith your SMB share. It enablesthe useof a setofpre-configuredcommandstoforexampledeletefiles.Thereply messages depend on the selected command. Everycommand option is explainedwithinthehelptext. Anexample configurationto send files is shownbelow.78 +==== 3.1.9 One of my remote files is not picked up from the SFTP server (without any warning) ==== 85 85 86 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-outbound-gateway-filled-in.png]] 80 +The default local filter is _AcceptOnceFileListFilter_. This can be replaced by your file list filter on the _FTP inbound channel adapter's_. 81 +If every day you retrieve a file with the same filename and the _Delete remote files_ property is set, it is advised to use a different local filename. You can add the current timestamp, for example. 87 87 88 -{{info}} 89 -Please note that for some commands an SpEL expression is required to respresent a path. This setting can be found in the advanced settings. An example for the mget command could be *.txt to get only text files from the directory. 90 -{{/info}} 83 +==== 3.1.10 Which mode is needed ==== 91 91 92 - Allavailableoptionsare:85 +When running in the current-generation architecture (G3) the FTP always needs to run **passive** mode. 93 93 94 -* List files 95 -* List file names 96 -* Retrieve file 97 -* Retrieve multiple files 98 -* Remove file(s) 99 -* Move/rename file 100 -* Send file 101 -* Send mulitple files 87 +=== 3.2 Configuration in eMagiz === 102 102 103 -T hisconcludesour microlearning,inwhich welearned howtoset upthe connectivitywithanSMB.89 +To configure the connection between eMagiz and the FTP, we need two (or three) components. This depends on whether we want to read, write or do both while communicating with the FTP. If we're going to do both, we need both of the functional components. In all other scenarios, you only need one of the functional components. The functional components that you might need are called: 104 104 91 +* FTP Inbound Channel adapter 92 +* FTP Outbound Channel adapter 93 + 94 +On top of that, you need one of the following support objects. If you are unsure of which to use, please check out the information above in this microlearning. 95 + 96 +* Default FTP caching session factory 97 +* Default FTP session factory 98 + 99 +In this microlearning, we will use the FTP Inbound channel adapter combined with the Default FTP session factory to illustrate the configuration. Please note that any other combination works similarly. To configure the connection with the FTP, we first navigate to the Create phase of eMagiz. Here we open the flow we want to edit. In this example, that will be an entry flow as we want to retrieve (read) data from the FTP. 100 + 101 +When you have opened the flow, you need to enter "Start Editing" mode. After you have done so, we first add the support object to our flow. In this case, we will use the Default FTP session factory. 102 + 103 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--default-ftp-session-factory-empty.png]] 104 + 105 +Here, we need to define at least the host and the port. Note that the username and password are optional for an FTP, which makes it less secure. Although in practice, we generally see that the FTP is secured with the help of a username-password combination. As a best practice, we use property references to fill in the various elements. 106 + 107 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--default-ftp-session-factory-filled-in.png]] 108 + 109 +The settings on the Advanced tab don't have to be changed in most cases. If your specific setup does require a change to these settings, please consult the help texts on the component level for advice. 110 + 111 +Now that we have configured the support object adding the FTP inbound channel adapter to the flow has become time. 112 + 113 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-inbound-channel-adapter-empty.png]] 114 + 115 +In this component, we need to define the remote directory where the original files are located. We need to specify the local directory used to store the files before they are processed temporarily. Furthermore, we need to link the support object we have just created and define a poller. For that last one, the best practice is the use of a cron trigger. 116 + 117 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-inbound-channel-adapter-filled-in.png]] 118 + 119 +Apart from these configurations, you could also add a filter, just as we learned in the Crash Course Messaging on file-based connectivity. Finishing things off, we should consider the delete behavior we will use. Based on the filter and the business requirements, whether to delete and when to delete could differ. So please consider all your options in that regard. This concludes our microlearning, in which we learned how to set up the connectivity with an FTP. 120 + 105 105 == 4. Key takeaways == 106 106 107 -* SMB(ServerMessage Block) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections.108 -* In an SMBtransaction, the end user's computer is typically called the localhost. The second computer involved inSMBis a remote host, which is usually a server.109 -* Servers must be set up to run SMBservices, and the client must haveSMBsoftware installed to access these services.110 -* eMagiz provides several components to set up the SMBconnection123 +* FTP (File Transfer Protocol) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections. 124 +* In an FTP transaction, the end user's computer is typically called the localhost. The second computer involved in FTP is a remote host, which is usually a server. 125 +* Servers must be set up to run FTP services, and the client must have FTP software installed to access these services. 126 +* eMagiz provides several components to set up the FTP connection 111 111 112 112 == 5. Suggested Additional Readings == 113 113 114 114 If you are interested in this topic and want more information, please read the release notes provided by eMagiz. Furthermore, check out these links: 115 115 116 -* [[SMB Support>>https://docs.spring.io/spring-integration/reference/smb.html||target="blank"]] 117 -* [[SMB Overview>>https://learn.microsoft.com/en-us/windows-server/storage/file-server/file-server-smb-overview||target="blank"]] 132 +* [[FTP Inbound>>https://docs.spring.io/spring-integration/docs/2.1.x/reference/html/ftp.html#ftp-inbound||target="blank"]] 133 +* [[FTP Session Factory>>https://docs.spring.io/spring-integration/docs/4.3.x/reference/html/ftp.html#ftp-session-factory||target="blank"]] 134 +* [[FTP Explained>>https://searchnetworking.techtarget.com/definition/File-Transfer-Protocol-FTP||target="blank"]] 118 118 119 119 )))((({{toc/}}))){{/container}}{{/container}} 
 
