aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/CoreModules/Asset/FlotsamAssetCache.cs53
1 files changed, 25 insertions, 28 deletions
diff --git a/OpenSim/Region/CoreModules/Asset/FlotsamAssetCache.cs b/OpenSim/Region/CoreModules/Asset/FlotsamAssetCache.cs
index 2afe065..103228f 100644
--- a/OpenSim/Region/CoreModules/Asset/FlotsamAssetCache.cs
+++ b/OpenSim/Region/CoreModules/Asset/FlotsamAssetCache.cs
@@ -36,12 +36,10 @@ using System.Runtime.Serialization;
36using System.Runtime.Serialization.Formatters.Binary; 36using System.Runtime.Serialization.Formatters.Binary;
37using System.Threading; 37using System.Threading;
38using System.Timers; 38using System.Timers;
39
40using log4net; 39using log4net;
41using Nini.Config; 40using Nini.Config;
42using Mono.Addins; 41using Mono.Addins;
43using OpenMetaverse; 42using OpenMetaverse;
44
45using OpenSim.Framework; 43using OpenSim.Framework;
46using OpenSim.Framework.Console; 44using OpenSim.Framework.Console;
47using OpenSim.Region.Framework.Interfaces; 45using OpenSim.Region.Framework.Interfaces;
@@ -810,34 +808,36 @@ namespace OpenSim.Region.CoreModules.Asset
810 #region Console Commands 808 #region Console Commands
811 private void HandleConsoleCommand(string module, string[] cmdparams) 809 private void HandleConsoleCommand(string module, string[] cmdparams)
812 { 810 {
811 ICommandConsole con = MainConsole.Instance;
812
813 if (cmdparams.Length >= 2) 813 if (cmdparams.Length >= 2)
814 { 814 {
815 string cmd = cmdparams[1]; 815 string cmd = cmdparams[1];
816
816 switch (cmd) 817 switch (cmd)
817 { 818 {
818 case "status": 819 case "status":
819 if (m_MemoryCacheEnabled) 820 if (m_MemoryCacheEnabled)
820 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Memory Cache : {0} assets", m_MemoryCache.Count); 821 con.OutputFormat("Memory Cache : {0} assets", m_MemoryCache.Count);
821 else 822 else
822 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Memory cache disabled"); 823 con.OutputFormat("Memory cache disabled");
823 824
824 if (m_FileCacheEnabled) 825 if (m_FileCacheEnabled)
825 { 826 {
826 int fileCount = GetFileCacheCount(m_CacheDirectory); 827 int fileCount = GetFileCacheCount(m_CacheDirectory);
827 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File Cache : {0} assets", fileCount); 828 con.OutputFormat("File Cache : {0} assets", fileCount);
829 con.Output("Deep scans have previously been performed on the following regions:");
828 830
829 foreach (string s in Directory.GetFiles(m_CacheDirectory, "*.fac")) 831 foreach (string s in Directory.GetFiles(m_CacheDirectory, "*.fac"))
830 { 832 {
831 m_log.Info("[FLOTSAM ASSET CACHE]: Deep scans have previously been performed on the following regions:");
832
833 string RegionID = s.Remove(0,s.IndexOf("_")).Replace(".fac",""); 833 string RegionID = s.Remove(0,s.IndexOf("_")).Replace(".fac","");
834 DateTime RegionDeepScanTMStamp = File.GetLastWriteTime(s); 834 DateTime RegionDeepScanTMStamp = File.GetLastWriteTime(s);
835 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Region: {0}, {1}", RegionID, RegionDeepScanTMStamp.ToString("MM/dd/yyyy hh:mm:ss")); 835 con.OutputFormat("Region: {0}, {1}", RegionID, RegionDeepScanTMStamp.ToString("MM/dd/yyyy hh:mm:ss"));
836 } 836 }
837 } 837 }
838 else 838 else
839 { 839 {
840 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File cache disabled"); 840 con.Output("File cache disabled");
841 } 841 }
842 842
843 break; 843 break;
@@ -845,7 +845,7 @@ namespace OpenSim.Region.CoreModules.Asset
845 case "clear": 845 case "clear":
846 if (cmdparams.Length < 2) 846 if (cmdparams.Length < 2)
847 { 847 {
848 m_log.Warn("[FLOTSAM ASSET CACHE]: Usage is fcache clear [file] [memory]"); 848 con.Output("Usage is fcache clear [file] [memory]");
849 break; 849 break;
850 } 850 }
851 851
@@ -869,11 +869,11 @@ namespace OpenSim.Region.CoreModules.Asset
869 if (m_MemoryCacheEnabled) 869 if (m_MemoryCacheEnabled)
870 { 870 {
871 m_MemoryCache.Clear(); 871 m_MemoryCache.Clear();
872 m_log.Info("[FLOTSAM ASSET CACHE]: Memory cache cleared."); 872 con.Output("Memory cache cleared.");
873 } 873 }
874 else 874 else
875 { 875 {
876 m_log.Info("[FLOTSAM ASSET CACHE]: Memory cache not enabled."); 876 con.Output("Memory cache not enabled.");
877 } 877 }
878 } 878 }
879 879
@@ -882,24 +882,22 @@ namespace OpenSim.Region.CoreModules.Asset
882 if (m_FileCacheEnabled) 882 if (m_FileCacheEnabled)
883 { 883 {
884 ClearFileCache(); 884 ClearFileCache();
885 m_log.Info("[FLOTSAM ASSET CACHE]: File cache cleared."); 885 con.Output("File cache cleared.");
886 } 886 }
887 else 887 else
888 { 888 {
889 m_log.Info("[FLOTSAM ASSET CACHE]: File cache not enabled."); 889 con.Output("File cache not enabled.");
890 } 890 }
891 } 891 }
892 892
893 break; 893 break;
894 894
895 case "assets": 895 case "assets":
896 m_log.Info("[FLOTSAM ASSET CACHE]: Ensuring assets are cached for all scenes."); 896 con.Output("Ensuring assets are cached for all scenes.");
897 897
898 Util.FireAndForget(delegate { 898 Util.FireAndForget(delegate {
899 int assetReferenceTotal = TouchAllSceneAssets(true); 899 int assetReferenceTotal = TouchAllSceneAssets(true);
900 m_log.InfoFormat( 900 con.OutputFormat("Completed check with {0} assets.", assetReferenceTotal);
901 "[FLOTSAM ASSET CACHE]: Completed check with {0} assets.",
902 assetReferenceTotal);
903 }); 901 });
904 902
905 break; 903 break;
@@ -907,7 +905,7 @@ namespace OpenSim.Region.CoreModules.Asset
907 case "expire": 905 case "expire":
908 if (cmdparams.Length < 3) 906 if (cmdparams.Length < 3)
909 { 907 {
910 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Invalid parameters for Expire, please specify a valid date & time", cmd); 908 con.OutputFormat("Invalid parameters for Expire, please specify a valid date & time", cmd);
911 break; 909 break;
912 } 910 }
913 911
@@ -925,28 +923,27 @@ namespace OpenSim.Region.CoreModules.Asset
925 923
926 if (!DateTime.TryParse(s_expirationDate, out expirationDate)) 924 if (!DateTime.TryParse(s_expirationDate, out expirationDate))
927 { 925 {
928 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: {0} is not a valid date & time", cmd); 926 con.OutputFormat("{0} is not a valid date & time", cmd);
929 break; 927 break;
930 } 928 }
931 929
932 if (m_FileCacheEnabled) 930 if (m_FileCacheEnabled)
933 CleanExpiredFiles(m_CacheDirectory, expirationDate); 931 CleanExpiredFiles(m_CacheDirectory, expirationDate);
934 else 932 else
935 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File cache not active, not clearing."); 933 con.OutputFormat("File cache not active, not clearing.");
936 934
937 break; 935 break;
938 default: 936 default:
939 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Unknown command {0}", cmd); 937 con.OutputFormat("Unknown command {0}", cmd);
940 break; 938 break;
941 } 939 }
942 } 940 }
943 else if (cmdparams.Length == 1) 941 else if (cmdparams.Length == 1)
944 { 942 {
945 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache status - Display cache status"); 943 con.Output("fcache assets - Attempt a deep cache of all assets in all scenes");
946 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache clearmem - Remove all assets cached in memory"); 944 con.Output("fcache expire <datetime> - Purge assets older then the specified date & time");
947 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache clearfile - Remove all assets cached on disk"); 945 con.Output("fcache clear [file] [memory] - Remove cached assets");
948 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache cachescenes - Attempt a deep cache of all assets in all scenes"); 946 con.Output("fcache status - Display cache status");
949 m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache <datetime> - Purge assets older then the specified date & time");
950 } 947 }
951 } 948 }
952 949