Why is the value result of cat variable different from that of direct cat variable?

after watching Uncle Psy"s linux cuisine, I wrote an identical script on the knowledge of learning service, but it didn"t work. Is this the wrong way to write it? The
process is as follows:
[root@localhost backups]-sharp ls
backup.log backup.sh backup.sh.bak backup-system-2019-02-12.tar.gz test.txt
[root@localhost backups]-sharp source= ". / {test.txt,backup.sh}"
[root@localhost backups]-sharp echo $source
. / {test.txt,backup.sh}
[root@localhost backups]-sharp cat $source
cat:. / {test.txt Backup.sh}: there is no file or directory
[root@localhost backups]-sharp cat. / {test.txt,backup.sh}
test

< H1 >! / bin/bash < / H1 >

source= "/ etc / home / root / var/lib / var/spool/ {cron,at,mail}"
target= "/ backups/backup-system-$ (date +% Y-%m-%d) .tar.gz"
[!-d / backups] & & mkdir / backups
tar-zcvf ${target} ${source} & > / backups/backup.log

I found that running this cat $source didn"t produce the expected results. Really look for the existence of. / {test.txt,backup.sh}. The function of this usage has not been realized. But it"s normal to directly use cat. / {test.txt,backup.sh} to get the desired results.

source= ". / {test.txt,backup.sh}"
cat $source
cat. / {test.txt,backup.sh}
cat. / {test.txt,backup.sh} is not equivalent to cat $source

Jun.17,2022

cat ./{test.txt,backup.sh}  cat './test.txt' && cat './backup.sh'
cat $source  cat './{test.txt,backup.sh}'

of course you can't find the'. / {test.txt,backup.sh} 'path

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1e66d3d-446b9.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1e66d3d-446b9.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?