small optimizations

This commit is contained in:
Athou
2013-04-22 10:23:53 +02:00
parent bb5d76109a
commit 839beb5d14

View File

@@ -4,6 +4,7 @@ import java.util.Calendar;
import java.util.List; import java.util.List;
import java.util.Queue; import java.util.Queue;
import javax.annotation.PostConstruct;
import javax.ejb.Lock; import javax.ejb.Lock;
import javax.ejb.LockType; import javax.ejb.LockType;
import javax.ejb.Singleton; import javax.ejb.Singleton;
@@ -27,29 +28,30 @@ public class FeedRefreshTaskGiver {
@Inject @Inject
MetricsBean metricsBean; MetricsBean metricsBean;
private int backgroundThreads;
private Queue<Feed> queue = Queues.newConcurrentLinkedQueue(); private Queue<Feed> queue = Queues.newConcurrentLinkedQueue();
@Lock(LockType.WRITE) @PostConstruct
public void add(Feed feed) { public void init() {
queue.add(feed); backgroundThreads = applicationSettingsService.get()
feed.setLastUpdated(Calendar.getInstance().getTime()); .getBackgroundThreads();
feedDAO.update(feed);
} }
@Lock(LockType.WRITE) @Lock(LockType.WRITE)
public Feed take() { public Feed take() {
if (queue.peek() == null) { Feed feed = queue.poll();
if (feed == null) {
List<Feed> feeds = feedDAO List<Feed> feeds = feedDAO
.findNextUpdatable(50 * applicationSettingsService.get() .findNextUpdatable(50 * backgroundThreads);
.getBackgroundThreads()); for (Feed f : feeds) {
for (Feed feed : feeds) { queue.add(f);
queue.add(feed); f.setLastUpdated(Calendar.getInstance().getTime());
feed.setLastUpdated(Calendar.getInstance().getTime());
} }
feedDAO.update(feeds); feedDAO.update(feeds);
feed = queue.poll();
} }
metricsBean.feedRefreshed(); metricsBean.feedRefreshed();
return queue.poll(); return feed;
} }
} }