Validating ftp transfer from Unix Server

Posted on 2007-04-02
Last Modified: 2013-12-20
I need to script the following task and place it in a cron;
I need to ftp two data files from our Unix Server to a common ftp file server. Once the file transfer is complete, I must send a header or flag file that tells a remote process on the ftp server tthat the transfer is complete otherwise I need to send a mailx out that indicates the transfer failed.
What would be the best way to determine if my transfer was complete. My first inclination is to compare file sizes between my local unix file and the remote ftp server file but am not clear on how to do that. I am unable to remotely connect to the ftp server with anything other than ftp. (ie. rsh ssh...)  Any help would be appreciated.
Question by:GeekMan
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 7
  • 3
  • 2
LVL 38

Expert Comment

ID: 18841108
why not using rsyn + ssh to do the job, it is easier and secure. it can perform the validation on fly.

more infor about rsync:

If you still want to  plain text file, the best you can do is you
use script to ftp login to your server, run ls -al command inside session and redirct  the output to a file, then the files size in the file against the file size you have download.

Author Comment

ID: 18842708
redirecting results in a zero byte local (unix) file that is of no value.

Author Comment

ID: 18846286
rsync or ssh....Unfortunately, I have no control over the technology used on the remote server. I have suggested these but so far ftp is the only thing we have available currently
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 84

Accepted Solution

ozo earned 125 total points
ID: 18847112
Are you saying that
ls -al > file
creates a zero byte file?
even if the directory was empty it should have listed . and ..
If it llists the two data files, then you can use it as the  header or flag file that a a remote process can read to compare file sizes
LVL 38

Assisted Solution

yuzh earned 125 total points
ID: 18847986
How did you redirect the out put, here's an example script
to get the filelist.txt:

# !/bin/ksh
ftp -n  $FTPSERVER <<EOF
lcd /path-to/myfiledir
ls -al
# Make sure that there is no WHITE space before EOF
}> /path-to/filelist.txt


the output is in /path-to/filelist.txt
then check filelist.txt
LVL 84

Expert Comment

ID: 18848688
was this supposed to run on the machine the files are coming from, or on the machine tho files are going to?
LVL 38

Expert Comment

ID: 18848740
I assume that you are runing the script in your locat machine to get the file list in the FTP server, and use the file list to compare the file
size you have download.

Author Comment

ID: 18853679
This is what I have so far. When I tee the output into my log file I get nothing. If I use the brackets { } as you suggested above, my script misinterprets the ftp code...(some of the code deals with alias package locations...disregard that.)

if [[ -z $PKG ]];then . ~/.profile -q;fi

case ${PKG_LOC} in
      plf)      EDMS_AREA=west;;
      cin)      EDMS_AREA=east;;

export EDMS_AREA
export psn_file='edm_psn_'${EDMS_AREA}
export xfm_file='edm_xfm_'${EDMS_AREA}
export psn_hdr='edm_psn_'${EDMS_AREA}
export xfm_hdr='edm_xfm_'${EDMS_AREA}

filelist=${psn_file}' '${xfm_file}
cd ${CES_HOME}/edm_exports

if SvcPkg -q;then
      print "Accessing Export Directory...\n"
      chmod 775 *.txt
      # first loop is psn file, 2nd loop is xfm file..
      for file in $filelist; do
            export fout=$file'_out.txt'
            export fhdr=$file'_hdr.txt'
            export lfsize=`wc -c ${fout} | cut -d" " -f1`
            print "Begin ${fout} File Transfer at:" $(date)

`ftp -inv <<-END_FTP
prompt off
cd /ces/edm/${EDMS_AREA}
delete ${fout}
delete ${fhdr}
put ${fout}
size ${fout}
END_FTP` | tee transfer.log

            export rfsize=`grep 213 transfer.log | cut -d" " -f2`
            if [[ ${lfsize} -eq ${rfsize} ]];

ftp -inv <<-END_FTP1
cd /ces/edm/${EDMS_AREA}
put ${fhdr}
                  print ${fout}" file sizes did not match.."
      echo "Svc Package is not located on this node, this script will now exit."

# Removed loginname and password by yuzh {Page Editor}

Author Comment

ID: 18853848
(Community Support)..Please delete this question.

Author Comment

ID: 18876683
Vee_Mod, what I'd really like is an edit button that I can use to edit the posts that I author. Seems like you offered that in earlier versions..??
The bottom line is that I don't want the username and password shared in my 4:41pm post on this question...... whatever we have to do to accomplish this. If it mean deleteing the question then yes, let's delete it. If you have other options then please exercise them.....As a user I have none. (except to have never posted it to begin with!)

Thank you..

Author Comment

ID: 18878783
Thank you Vee_Mod... Mission accomplished....

Author Comment

ID: 18889042
Thanks...I transgressed the unwritten law...I know, I should have my head nailed to a table by one of the Piranha brothers.......!
It had been a long day....i was tired....I hit the submit button and then realizes.."Oh $#&%%.!!!."

Thanks again....

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction: Ownerdraw of the grid button.  A singleton class implentation and usage. Continuing from the fifth article about sudoku.   Open the project in visual studio. Go to the class view – CGridButton should be visible as a class.  R…
Have you tried to learn about Unicode, UTF-8, and multibyte text encoding and all the articles are just too "academic" or too technical? This article aims to make the whole topic easy for just about anyone to understand.
Learn several ways to interact with files and get file information from the bash shell. ls lists the contents of a directory: Using the -a flag displays hidden files: Using the -l flag formats the output in a long list: The file command gives us mor…
Learn how to find files with the shell using the find and locate commands. Use locate to find a needle in a haystack.: With locate, check if the file still exists.: Use find to get the actual location of the file.:

756 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question