Changes for page SMB Connectivity
                  Last modified by Danniar Firdausy on 2024/09/18 20:40
              
      
      From version  7.1 
    
    
              edited by Bouke Reitsma
        
on 2024/05/03 09:30
     on 2024/05/03 09:30
      Change comment:
              There is no comment for this version
          
         
      To version  26.1 
    
    
              edited by Bouke Reitsma
        
on 2024/05/13 16:21
     on 2024/05/13 16:21
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -1,4 +1,5 @@ 1 -{{container}}{{container layoutStyle="columns"}}((( 1 +{{container}} 2 +{{container layoutStyle="columns"}}((( 2 2 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, there is a third communication protocol that can be used for file transfer. In this microlearning we will take a look at Server Message Block (SMB) connectivity within eMagiz. 3 3 4 4 Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]]. ... ... @@ -28,110 +28,93 @@ 28 28 * Servers must be set up to run SMB services, and the client must have SMB software installed to access these services. 29 29 * eMagiz provides several components to set up the SMB connection 30 30 31 ------------------------------------------------------------------------------------------------------------------------------------ 32 - 33 33 So, where the file pickup component searches on the local host for the correct directory, the idea of the SMB 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 SMB protocol. That is, in a nutshell, the difference between setting up an SMB connection and communicating with local directories. 34 34 35 -eMagiz provides only one support objects to connect to an FTP:34 +eMagiz provides only one support objects to connect to an SMB: 36 36 37 -* DefaultSMB36 +* SMB session factory 38 38 39 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity- ftp-connectivity--ftp-support-objects.png]]38 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-support-object.png]] 40 40 41 - Themain difference between the two is the caching part.The caching sessionactory comes with the option to re-use the existingsession for multiplerequests. In other words, this way, you do nothave to authenticate yourself every time you wantto communicate with the FTP. This behavior is beneficialif a high frequency of communication is needed between eMagizand the FTP to handle the incoming and outgoing data packages.40 +=== 3.1 Configuration in eMagiz === 42 42 43 - If youonlyinitiate communication infrequently,for example,once perday,thedefaultsessionfactorybecomesmoreinterestingasthisclosesthesessionaftereachtransmission.Thisbehaviorisbeneficialin casesoflow-frequencycommunicationbecauseotherwise,thesessionwouldremain activeforanextensiveperiod.42 +To configure the connection between eMagiz and the SMB, we need two (or three) components. This depends on whether we want to read, write or do both while communicating with the SMB. 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: 44 44 45 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-caching-help-text.png]] 44 +* SMB inbound Channel adapter 45 +* SMB outbound Channel adapter 46 46 47 - ===3.1 Bestracticesfor usingFTP===47 +On top of that, you need the following support objects. 48 48 49 - ====3.1.1Whichsession factorydo I need? ====49 +* SMB session factory 50 50 51 - Whenoccasionally retrievingorwriting files toFTP,use the_DefaultFTPsession factory_.Anewconnectionwill betup whenyou use the _DefaultFTPsessionfactory_foreverymessage/file.OnsomeFTPservers,thismight takeuptosecondsforeachlogin.Thisfactmight impacttheperformanceofyour flow.51 +In this microlearning, we will use the SMB inbound channel adapter combined with the SMB session factory to illustrate the configuration. Please note that any other combination works similarly. To configure the connection with the SMB, 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 SMB. 52 52 53 -When you needbetterperformance(saywritingmultiplefiles ina minuteorretrievingfileseveryminute),use the_DefaultFTP **caching**sessionfactory_. The_DefaultFTP **caching**session factory_sharesFTP sessionsformessages in your flow.53 +When you have opened the flow, you need to enter "Start Editing" mode. After you have done so, we first add the SMB session factory support object to our flow. 54 54 55 - ==== 3.1.2 DoIhavetoset upaymechanism? ====55 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-session-factory-empty.png]] 56 56 57 - When writing files to FTP,it is advisableto set a retry mechanism. Find theadvanced tabonyour _FTP outboundchannel adapter_. Under_Requestandleradvice chain_ add a _Retry Advice_.57 +Here, we need to define the following: 58 58 59 -==== 3.1.3 I get a _Failed to list files/items_ or a _Failed to obtain pooled item_. What can I do? ==== 59 +* Host 60 +* Port 61 +* Username 62 +* Password 63 +* Share and directory 60 60 61 -Incorrect connection settings can cause this. Check whether the correct properties have been set and whether the runtime has retrieved the latest properties. 65 +{{info}} 66 +The value for the share and directory field is the main folder for your file share. If the main folder is the exchange folder, then within the SMB inbound channel adapter, a / is needed as remote directory. 67 +{{/info}} 62 62 63 - ==== 3.1.4 Igeta_Failed to list files /items_, a _Pipeclosed_or an_inputstreamlosed_.What canI do? ====69 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-session-factory-filled-in.png]] 64 64 65 - AclosedFTPsession cancause thesenotificationsdue toinactivity.For the_DefaultFTP**caching**sessionfactory_,alwayssetthe_Serveralive interval_propertyto30000 (ms).71 +In the advanced tab there are only two settings to change. The minimum and maximum SMB protocol version. By default, these are set to 2.02 and 3.1.1 respectively to allow a wide range of save protocol version. However, if you want to only allow the best performing version, the minimum 3.0.2 is advised. If you aim for the best secured connection version 3.1.1 has the most functionality in this area. The best practise on this is set the minimum version as high as possible to mimize risks. 66 66 67 - ====3.1.6I geta_Failed towriteto_.What canIdo?====73 +Now that we have configured the support object,we can add the SMB inbound channel adapter to the flow. 68 68 69 - Maybethe target folderdoesnotexist, andthe_Auto-createdirectory_ is off. Itis also possiblethat theon settingsare incorrect. Check whether the correct properties havebeenset andwhether the runtimehas retrievedthe latest properties.75 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-inbound-channel-adapter-empty.png]] 70 70 71 - ====3.1.7Ioftenget'Disconnecting fromsftp.example.comport22'andthena'Caughtan exception,leavingmain loopdue toSocketclosed'warnings.====77 +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. 72 72 73 - Toomany connections can causethistothesameserveratthesame time. If you havemanyflowsngto thesame FTP server, ensure that the crons donottriggersimultaneously.79 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-inbound-channel-adapter-filled-in.png]] 74 74 75 -= ===3.1.8I get a'Failed to createSFTPClient'====81 +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. In case there are multiple readers from the folder and/or there are legal requirements to store source files for a certain time period, you should not use the delete remote files option. However, not deleting files read files can cause overloading the machine if no alternative delete policies is in place. 76 76 77 - SFTP,FTP,and FTPS arethree different remote file transfer protocolswith their _session factory_components in the eMagiz flow designer. Make sure you use the one that corresponds to the server's protocol.83 +=== 3.2 SMB Gateway === 78 78 79 - ====3.1.9One ofmyremotefilesisnot pickedupfrom theSFTPserver(withoutanywarning)====85 +The SMB Gateway is an additional component that can be used to interact with your SMB share. It enables the use of a set of pre-configured commands to for example delete files. The reply messages depend on the selected command. Every command option is explained within the helptext. An example configuration to send files is shown below. 80 80 81 -The default local filter is _AcceptOnceFileListFilter_. This can be replaced by your file list filter on the _FTP inbound channel adapter's_. 82 -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 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-smb-connectivity-smb-outbound-gateway-filled-in.png]] 83 83 84 -==== 3.1.10 Which mode is needed ==== 89 +{{info}} 90 +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 **myfilesdirectory/** to get only files from this directory. 91 +{{/info}} 85 85 86 - Whenrunning in the current-generationarchitecture (G3) the FTP always needstorun**passive** mode.93 +All available options are: 87 87 88 -=== 3.2 Configuration in eMagiz === 95 +* List files 96 +* List file names 97 +* Retrieve file 98 +* Retrieve multiple files 99 +* Remove file(s) 100 +* Move/rename file 101 +* Send file 102 +* Send mulitple files 89 89 90 -T o configuretheconnection between eMagiz andtheFTP, we need two(orthree) components. This depends on whetherwe want toread, write or do both while communicatingwiththe FTP. Ifwe're going to do both,we needbothfthe functionalcomponents.In all other scenarios, youonly need one ofthefunctional components. The functional components thatyoumight needare called:104 +This concludes our microlearning, in which we learned how to set up the connectivity with an SMB. 91 91 92 -* FTP Inbound Channel adapter 93 -* FTP Outbound Channel adapter 94 - 95 -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. 96 - 97 -* Default FTP caching session factory 98 -* Default FTP session factory 99 - 100 -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. 101 - 102 -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. 103 - 104 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--default-ftp-session-factory-empty.png]] 105 - 106 -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. 107 - 108 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--default-ftp-session-factory-filled-in.png]] 109 - 110 -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. 111 - 112 -Now that we have configured the support object adding the FTP inbound channel adapter to the flow has become time. 113 - 114 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-inbound-channel-adapter-empty.png]] 115 - 116 -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. 117 - 118 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-ftp-connectivity--ftp-inbound-channel-adapter-filled-in.png]] 119 - 120 -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. 121 - 122 122 == 4. Key takeaways == 123 123 124 -* FTP(FileTransferProtocol) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections.125 -* In an FTPtransaction, the end user's computer is typically called the localhost. The second computer involved inFTPis a remote host, which is usually a server.126 -* Servers must be set up to run FTPservices, and the client must haveFTPsoftware installed to access these services.127 -* eMagiz provides several components to set up the FTPconnection108 +* SMB (Server Message Block) is a network protocol for transmitting files between computers over Transmission Control Protocol/Internet Protocol (TCP/IP) connections. 109 +* In an SMB transaction, the end user's computer is typically called the localhost. The second computer involved in SMB is a remote host, which is usually a server. 110 +* Servers must be set up to run SMB services, and the client must have SMB software installed to access these services. 111 +* eMagiz provides several components to set up the SMB connection 128 128 129 129 == 5. Suggested Additional Readings == 130 130 131 131 If you are interested in this topic and want more information, please read the release notes provided by eMagiz. Furthermore, check out these links: 132 132 133 -* [[FTP Inbound>>https://docs.spring.io/spring-integration/docs/2.1.x/reference/html/ftp.html#ftp-inbound||target="blank"]] 134 -* [[FTP Session Factory>>https://docs.spring.io/spring-integration/docs/4.3.x/reference/html/ftp.html#ftp-session-factory||target="blank"]] 135 -* [[FTP Explained>>https://searchnetworking.techtarget.com/definition/File-Transfer-Protocol-FTP||target="blank"]] 117 +* [[SMB Support>>https://docs.spring.io/spring-integration/reference/smb.html||target="blank"]] 118 +* [[SMB Overview>>https://learn.microsoft.com/en-us/windows-server/storage/file-server/file-server-smb-overview||target="blank"]] 136 136 137 -)))((({{toc/}}))){{/container}}{{/container}} 120 +)))((({{toc/}}))){{/container}} 121 +{{/container}} 
 
